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1.0 INTRODUCTION 

Western Digital's WD42C22C integrates a high 
performance, low cost Winchester formatter/con- 
troller, host interface, a buffer manager, and 
CRC/ECC generator/checker in a single 84-pin 
LSI device. Operating from a single +5V power 
supply, the WD42C22C is implemented in a low 
power CMOS design and is available in an 84-pin 
PLCC or PQFP (Figure 1). Figure 2 is a block 
diagram of the WD42C22C. 



1.1 FEATURES 

• Enhanced host interface 

. IBM Personal Computer AT and XT port 

compatible 
. Supports AT speeds up to 1 6 MHz, 1 wait 

state I/O and wait state memory using 1 20 

nsec static RAM (SRAM) 
. Supports AT speeds up to 1 6 MHz, 1 wait 

state I/O and wait state memory using 1 00 

nsec SRAM 
. Selectable DMA or programmed I/O data 

transfers in all host interface modes 
. Host port slave mode compatible with ALE 

based peripherals such as the WD33C93 

SBIC 
. Host transfer rates up to 4 Mwords/sec for 

AT, 4 MB/sec for XT, 10 MB/sec for SCSI 

. Internal 1 2 mA high current drivers for direct 
connection to the XT or AT system bus 

• Advanced buffer manager 

. Supports 1 :1 interleave without resorting to 

wait states 
. Direct interface for up to 32 KB of static RAM 
. Sustained RAM bandwidth up to 10 MB/sec 
. Pipelined host and disk address counters 

. Operates as either ring or scatter-gather 

buffer 
. Allows full track buffering and facilitates look 

ahead cacheing algorithms 
. Adaptable disk controller 
. Software selectable MFM, RLL 2,7, or NRZ 

disk interface 
. Software selectable 56 bit ECC, 32 bit ECC, 

or16bitCRC 
. Software selectable 5, 1 1 , or 22 bit error 

correction span 




,952 SSBqdqqoqS 
xxxx>>xxxxxxxx 



nnnn n n n n nnnnn n n n nnn nn 



EA"RT?/AME 
WG 



/1110 987664 3 2 184038201807978777675 

CJ 12 
EZ 13 



5CT/DRUN I 



BG I 

RC I 

WF I 

BRT57 I 

V$s i 

RESET ! 

KtEIRT ! 

ALE/AS I 

REBDS I 

RiWE/MR/W i 

ADO ! 

A01 I 

AD2 ! 

AD3 ! 

AD4 I 



ZD INTRQ 


ZZl BA14 


ZZ1 BA13 


Z3 8A12 


in BAH 


Z3 BA10 


ZZJ BA9 


Z3 BA8 


=ZJ BA7 


Z3 8A6 


Z3 BA5 


=3 BA4 


Z3 BA3 


ZZt BA2 


ZD BA1 


Z3 BAG 


Z3 BD7 


ZD BD8 


ZZ1 80S 


Z3 B04 


ZU BD3 



33.34.3£3J3738394041 42434445464748495051 5253 , 

iSiIunuuuuluuuuuuuuu 

§MfP§lllllIlli§§§ 



FIGURE 1. PIN DESIGNATION 



Software selectable default sector lengths of 

128, 256, 512, and 1024 bytes 

User programmable sector size up to 2048 

bytes 

Software selectable 3 bit or 4 bit head 

number field 

Reads and writes at 1:1 Interleave 
regardless of the formatted interleave 
1 5 Mbs data transfer rate for MFM and RLL 
24 Mbs data transfer rate for NRZ 
Supports hard or soft sectored formats 
Supports "zero latency" read operations 
Internal defect management of sector and 
track level alternates 
. Able to read ESDI defect list format 
. Supports sector servo schemes by disabling 

WRITE GATE over servo when formatting 
. Internal 48 mA drivers and Schmitt trigger 
input receivers for direct connection to the 
drive control cable 

Integrated support features 

. Programmable master/slave mode allows 
two Integrated Drive Electronics (IDE) disks 
on one connector 

. Supports both lntel-type(80xx) and 
Motorola-type(68xx) microcontrollers 
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Internal power-qualified reset to detect low 
Vdd 

• Low power sleep mode 

• Available in 84-pin PLCC or 84-pin PQFP 



1.2 DESCRIPTION 



1.2.1 Enhanced Host Interface 

The WD42C22C host interface port directly con- 
nects to the host system bus via internal 12 mA 
drivers. When operating in either AT or XT mode, 
all host control, data, and task file address lines 
directly connect to the WD42C22C. Mapping the 
device to the desired host system I/O addresses 



requires external address decode logic. Integrated 
I/O port compatible AT and XT task file registers 
assure system compatibility. 

To satisfy requirements for faster system bus 
rates and data transfers, the WD42C22C can 
operate in 12 MHz or 16 MHz, 1 wait state I/O 
channels (0 wait state memory) of 286 or 386 
microprocessors. DMA or PIO data operations 
transfer at a rate of 4 Mwords/sec (AT mode) or 4 
MB/sec (XT mode). In addition to traditional single 
mode DMA, burst mode DMA transfers are also 
available. 

An alternative host mode, slave mode, allows 
communication between the microcontroller and a 
peripheral device through the host interface. The 
slave device transfers data to the buffer RAM by 
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using a slave DMA scheme such as the WD-BUS 
mode in the WD33C93 SCSI bus interface con- 
troller (SBIC). 



1 .2.2 Advanced Buffer Management 

The WD42C22C contains an advanced buffer 
manager satisfying the interface requirements be- 
tween a byte or word wide host interface bus and 
a high speed serial disk interface. Optimized for 
the block oriented data structures of a disk con- 
troller, the WD42C22C can manage multiple sec- 
tor buffers up to 32 KB. Each sector buffer can be 
any size to 2055 bytes. Pipelined host and disk 
address counters enable sustained, simultaneous 
transfers on each port. Sufficient RAM buffer 
bandwidth is available to support 1 :1 interleaved 
20 Mb/sec disk transfers while simultaneously 
performing 16-bit host transfers at a rate in ex- 
cess of 3 Mwords/sec. Achieving maximum RAM 
bandwidth requires using 70 nsec static RAM. 

The pipelined structure of the buffer manager con- 
trols the buffer RAM in either a simple ring struc- 
ture or a more advanced scatter-gather structure. 



1 .2.3 Adaptable Disk Controller 

The WD42C22C's versatile design makes the 
device adaptable for a wide variety of disk inter- 
face operations. A designer can select from three 
data formats, MFM, RLL 2,7, or NRZ. Disk data 
rates range up to 15 Mbits/sec with MFM and RLL 
2,7 encoding, while NRZ data rates range up to 
24 Mbits/sec. To support varied data format re- 
quirements, the WD42C22C operates in hard or 
soft sectored mode with programmable sector 
sizes to 2048 bytes and programmable ID PLO, 
data PLO, and GAP lengths. 

Software selectable retry algorithms and 32 or 56- 
bit ECC polynomials enhance data integrity. Data 
integrity can further be ensured through the use of 
the device's built-in advanced defect manage- 
ment. The WD42C22C can be programmed to 
automatically detect the presence of a previously 
assigned defective sector and identify the location 
of the alternate sector. This allows access to alter- 
nate sectors without the typical additional rotation- 
al latency associated with defect handling. 

With the pipelined architecture of the buffer 
manager, the designer can program the disk con- 



troller to execute "zero-latency" multiple sector 
read operations. In this mode of operation, the 
WD42C22C immediately commences data trans- 
fer to the RAM buffer upon encountering the first 
sector on the desired track. All subsequent sec- 
tors transfer to the buffer within a single rotational 
period. Host transfers begin upon location of the 
first requested sector within the buffer. Simul- 
taneous host and disk transfers continue until all 
sectors are read from the drive. Zero-latency 
operation makes available an entire track of data 
to the host within one rotational period from the 
time the host requested the data. This differs from 
traditional implementations which read the entire 
track within one rotational period after the first re- 
quested sector has been located. Zero latency 
read operations eliminate the typical one-half rota- 
tional period average latency required to locate 
the first sector in full track data transfers 

The WD42C22C includes an internal power 
qualified reset circuit for power up and power 
down conditions. This circuit eliminates the need 
for costly external circuitry that traditionally per- 
formed this function. 

The WD42C22C features a multiplexed ad- 
dress/data bus on the microcontroller interface 
port and supports both Intel (80XX) and Motorola 
(68XX) type microcontrollers. An internal circuit 
automatically determines the connected 
microcontroller and configures the ports for direct 
interfacing. 

Internal 48 mA drivers and Schmitt triggers input 
receivers provide direct connection to the drive 
control cable. Programmable input polarities as- 
sist in integrated drive electronics (IDE) designs. 



1 .2.4 Flexibility of Application 

As a result of its level of integration, a designer 
can create a wide variety of products. In addition 
to traditional stand alone Winchester controller 
boards, the WD42C22C is ideal for multi-function 
boards, direct system motherboards, and IDE ap- 
plications. Special design considerations within 
the WD42C22C facilitate these applications. 



1 .2.5 Typical Application 

With an external microcontroller, buffer RAM, and 
a data separator such as the WD10C22B, the 
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WD42C22C forms the basis of a Winchester disk 
controller product. For AT and XT applications, 
direct interfacing is available to the system bus. In 
these applications, the WD42C22C requires ex- 
ternal address decoding to select the primary and 
secondary I/O address range of the WD42C22C. 
Other bus interfaces are supported via auxiliary 
bus controllers such as the WD33C93A SCSI Bus 
Interface Controller. 

For ST506 (MFM) and ST412HP (RLL) applica- 
tions, the WD42C22C directly connects to the 
WD10C22 data separator. (Like the WD42C22C, 
the WD10C22B supports both MFM and RLL en- 
coding methods.) An external microcontroller im- 
plements interface specific control lines, e.g. the 



ST506's STEP and DIRECTION signals. For 
ESDI applications, the WD42C22C operates in 
NRZmode. 



1 .2.6 Pin Descriptions 

This section lists the pin number, signal name, 
and function for all the WD42C22C's pins. The pin 
descriptions are arranged by functions. Table 1 
describes the pin designations for the host inter- 
face. Table 2 describes the pin designations for 
the local microcontroller interface. Table 3 
describes the pin designations for the buffer inter- 
face. Table 4 describes the pin designations for 
the drive interface. 
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PIN 
NUMBER 



MNEMONIC SIGNAL NAME 



I/O 



FUNCTION 



1 
2 
3 
4 



HAO 

HA1 

HA2 

HA9/ 

HALE 



IOCS16/ 
DREQ 



PAC K/ 
RCS 



HOST ADDRESS 
HOST ADDRESS 1 
HOST ADDRESS 2 
HOST ADDRESS 9/ 
HOST ALE 



HRE 


HOST READ 
ENABLE 


HWE 


HOST WRITE 
ENABLE 


HCS 


HOST CHIP 



I 
I 

I 

I/O 



I/O 



I/O 



I/O 



SELECT 



J/O CHIP SELECT 

16/ 

DMA REQUEST 



DMA ACKNOW- 



LEDGE/ 



RAM CHIP SELECT 



Schmitt-triggered input. These four inputs are 
used to address the internal registers. Internal 
decoding of these address signals is a function 
of the AT/XT and HSMB mode bits. Port com- 
patibility is maintained for both the AT and XT 
In slave host mode HALE is used by the 
peripheral device to latch the address from 
HDO through HD7. 

Schmitt-triggered in put. H RE is asserted by 
the AT or XT with HCS to read an intern al 
register or the FIFO . In slave mode, HRE is 
asserted when MRE is asserted. It can also be 
asserted by the slave peripheral in DMA mode. 

Schmitt-triggered in put. H WE is asserted by 
the AT or XT with HCS to write an intern al 
register or the FIFO . In slave mode, HRE is 
asserted when MRE is asserted. It is also as- 
serted by the slave peripheral in DMA mode. 

Schmitt-triggered input. HCS should be 
decoded from t he AT or XT add ress bus and is 
used to qualify HRE and HWE for host acces- 
ses. In slave mode, HCS is asserted when the 
local microcontroller is accessing the slave 
device address space. 

This output is programm able to function as the 
AT bus signal IOCS16 when the PIO mode is 
selected or as a DMA Request signal (DREQ) 
in the DMA mode. This output is tri-stated at 
power-up and remains tri-stated until the inter- 
face mo de is set by the local microcontroller. 
IOCS16 is an open-drain ouput. DREQ is a 
tri-state output. 

Schmitt-triggered input. DACK is asserted by 
the host in response to the DREQ signal 
asserti on in order to complete the DMA hand- 
shake. RCS is used in slave mode to qualify 
host data transfers to/from the FIFO. 



TABLE 1. HOST INTERFACE PIN DESCRIPTION 
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PIN 


MNEMONIC 


SIGNAL NAME 


I/O 


FUNCTION 


NUMBER 










23 






I/O 


Open-drain output and Schmitt input, can be 


RESET 


RESET 










wire-ORed with an external reset. The 










WD42C22C resets all logic except the Task 










File when this input is asserted. On power-up, 










or when requested by the host, this output is 










asserted. 


75 


HDO 


HOST DATA thru 


I/O 


Sch mitt-triggered inputs. These 16 pins are 


thru 


thru 


HOST DATA 15 




used during host 16-bit data transfers, and the 


82, 


HD1.5 






lower eight bits (HD0-HD7) are used for byte- 


40, 








wide host data transfers as well as all com- 


41, 
42, 








mand and status information transfers. 


44 
thru 










48 










74 


INTRQ 


INTERRUPT 
REQUEST 


I/O 


INTRQ indicates to the AT or XT that a data 
blocktransfer is requested or a command has 
been completed. In slave host mode INTRQ is 
asserted by the slave peripheral device. 


83 


Vss 


GROUND 




Ground. 


84 


Vdd 


+5V 




+5V 



TABLE 1. HOST INTERFACE PIN DESCRIPTION (CONT'D) 
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PIN 
NUMBER 


MNEMONIC 


SIGNAL NAME 


I/O FUNCTION 


22 
24 

25 

26 

27 

28 
thru 
35 

43 


Vss 
MCINT 

ALE/AS 

MRE/DS 

MWE/ 
MR/W 

ADO 
thru 
AD7 

Vss 


GROUND 

uCONTROLER 
INTERRUPT 

ADDRESS LATCH 
ENABLE/ 
ADDRESS STROBE 


Ground. 

This output is used as an interrupt signal in 
order to alert the local microcontroller it is 
necessary to check command parameters or 


status. For the XT mode, MCINT is asserted 
when the controller is selected. 

1 Schmitt-triggered input. ALE is used to latch 
the lower eight address bits from the multi- 
plexed address/data lines (AD7-AD0). AS is 
used for this function when tied to a Motorola 
type microcontroller. 

1 Schmitt-triggered input. MRE is asserted by 
the local microcontroller to read an internal 
register or the buffer. DS is used in Motorola 
type microcontrollers to enable the data trans- 
fer. 

1 Schmitt-triggered input. MWE is asserted by 
the local microcontroller to write an internal 
register or the buffer. MR/W is used by 
Motorola type microcontrollers to set the direc- 
tion of data transfers. 

I/O Schmitt-triggered inputs. These multiplexed 
address/data lines are used to load the 
register/buffer address on the falling edge of 
ALE, and are used for data transfers to/from 
the local microcontroller. 

Ground. 


jiCONTROLLER 
READ ENABLE 
/DATA STROBE 


uCONTROLLER 
WRITE ENABLE/ 
uC READ/WRITE 

ADDRESS/DATA 
thru 
ADDRESS/DATA 7 

GROUND 




TABLE 2. LOCAL MICROCONTROLLER INTERFACE PIN DESCRIPTION 
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PIN 
NUMBER 


MNEMONIC 


SIGNAL NAME 


I/O 


FUNCTION 


38 


XTALIN 


CRYSTAL 
INPUT 


I 


Crystal oscillator input. The crystal frequency 
is twice the buffer data rate. 


39 


XTALOUT 


CRYSTAL 
OUTPUT 





Crystal oscillator output. 


49 


BOE 


BUFFER OUTPUT 
ENABLE 





BOE is asserted by the chip to read data from 
the external SRAM buffer. 


50 


BWE 


BUFFER WRITE 
ENABLE 





BWE is asserted by the chip to write data into 
the external SRAM buffer. 


51 
thru 
58 


BDO 
thru 
BD7 


BUFFER DATA 

thru 

BUFFER DATA 7 


I/O 


Schmitt-triggered. Buffer data bus, which con- 
nects directly to a static RAM. 


59 

thru 

73 


BAO 
thru 
BA14 


BUFFER ADDRO 

thru 

BUFFER ADDR 14 


I/O 


Buffer address bus, for direct connection to 32 
KB of SRAM. In XT mode, also used to read 
jumper configuration data in Read Configura- 
tion Mode. In input mode, there is a low cur- 
rent internal pulldown. 



TABLE 3. BUFFER INTERFACE PIN DESCRIPTION 
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PIN 
NUMBER 



MNEMONIC SIGNAL NAME 



I/O 



FUNCTION 



10 



11 



12 



13 



WD 



LATE/ 
WCOUT 



AME/ 
EARLY 



WG 



LATE/ 
WCOUT 



ADDRES S MARK 
ENABLE/EARLY 



WRITE GATE 



14 


WC 


WRITE CLC 


15 


INDEX 

SCT/ 
DRUN 


INDEX 


16 


SECTOR/ 
DATA RUN 



17 



18 



RD 



RG 



WRITE DATA O WD is the MFM/NRZ write data written to the 

disk. It is shifted out at a rate determined by 
write clock. MFM write data should be 
synchronized by a D flip flop clocked at 10 
MHz (for 5 Mbs operation). 

O LATE is used along with EARLY in the Write 

Precompensation circuitry to control the delay 
of WD. 

In NRZ mode WCOUT is write clock out which 
can be used to qualify WD in an ESDI applica- 
tion. 

O In NRZ mode, this output is the Address Mark 
Enable signal for an ES DI drive . In MFM or 
RLL m ode, this output is EARLY. EARLY and 
LATE are used in the Write Precompensation 
circuitry to control the delay of WD. 

WG is asserted when valid data is to be written 
to the disk. It enables write current to t he head 
and is immediately de-asserted if a WRITE 
FAULT (WF) is detected. 

1 A clock used internally to control WD. (Up to 
10 MHz for ST412, up to 15 MHz for ESDI). 

I Schmitt-triggered INDEX input for direct con- 
nection to the drive control cable. 

1 Schm itt-triggered input. In hard sector mode, 
SCT is used to indicate the s tart of a sector. In 
soft sector NRZ mode, SCT indicates Address 
Mark Found. In soft sector MFM or RLL mode, 
DRUN indicates a sequence of MFM or RLL 
'0's or a sequence of MFM Ts has been 
detected. 

READ DATA I RD is MFM or NRZ read data from the drive. 

Data and clocks are separated internally for 
MFM data. 

READ GATE O RG is asserted to initiate a search for an ad- 

dress mark. It remains asserted until the end 
of the ID or data field. 



TABLE 4. DRIVE INTERFACE PIN DESCRIPTION 
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PIN 
NUMBER 


MNEMONIC 


SIGNAL NAME 


I/O 


FUNCTION 


19 

20 

21 

36 
37 


RC 
WF 


READ CLOCK 


I 

I 

I 





RC is typically generated from an oscillator 
phase-locked to the read data. 

Schmitt-triggered. WRITE FAULT input for 
direct connection to the drive control cable. 

Schmitt-triggered. DRIVE READY input for 
direct connection to the drive control cable. 

High-current open-drain DRIVE SELECT out- 
puts for direct connection to the drive control 
cable. 


WRITE FAULT 


DRDY 

DSO 
DS1 


DRIVE READY 


DRIVE SELECT 
DRIVE SELECT 1 



TABLE 4. DRIVE INTERFACE PIN DESCRIPTION (CONT'D) 



2.0 ARCHITECTURE 



2.1 POWER-QUALIFIED RESET 

This integrated function is used to reliably initialize 
flip-flops to a predictable state du ring the applica- 
tion of Vdd- It causes the RESET output signal to 
be asserted until VDD reaches a given threshold. 
It also forces a reset if the Vdd falls below a 
specified threshold. 



2.2 DRIVE INTERFACE LOGIC 

The drive interface contains high-current 48 mA 
drivers for direct connection of the drive select 
outputs to the drive control cable. Schmitt trigger 
input receivers connect the drive interface logic 
directly to the control cable inputs. 



2.3 DRIVE CONTROLLER ORGANIZATION 

The controller is composed of the following major 
sections: 

• PLA Control 

• CRC/ECC Logic 

• MFM/RLL Decoding 

• Address Mark Detector 

• Buffer and DMA Control 

• Task Register File 



The controller is designed to operate with 2 clock 
inputs, READ CLOCK (RC) and WRITE CLOCK 
(WC). The PLA controller, processor interface, 
and buffer control sections use the write clock 
input. The clock inputs are used for MFM, RLL, or 
NRZ decoding. The clock frequency is 10 MHz for 
a 10 Mbs data rate. 

The controller reads or writes disk data to a 15 
Mbs rate for MFM and RLL and 24 Mbs for NRZ. 
The RLL implementation is a (2,7,2,4,3) code 
based on the IBM 3370 code. The only difference 
lies in the assignments of the code words to the 7 
different data streams possible. Error propagation 
for a single bit error is limited to 4 bits. 

When programmed in the NRZ mode, the 
WD42C22C qualifies NRZ disk data using the 
Sector / Address Mark Detect signal, and also 
modifies the RG and WG signals to meet ESDI 
specifications. 

In all modes, the length of the PLO sync and gap 
fields are software programmable. The ID PLO 
sync field length, the Gap1/Gap3 length, the 
Gap1/Gap3 data bytes and the ID CRC pad 
bytes are programmable during the format com- 
mand. The data PLO sync field length and the 
data CRC/ECC pad bytes are programmable 
during the Write command. 

Figure 3 is a block diagram of the drive controller 
section of the WD42C22C. 
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FIGURE 3. DRIVE CONTROLLER BLOCK DIAGRAM 




2.4 PROGRAMMABLE LOGIC ARRAY (PLA) 
CONTROLLER 

The Programmabla Logic Array (PLA) controller 
interprets commands, e.g. write, read format, etc. 
This circuitry's operation is synchronized with the 
WC input. The PLA controller is started when a 
command is written into the command register. It 
generates control signals and operates in a hand- 
shake mode when communicating with the 
MFM/RLL decoding block. The MFM/RLL decod- 
ing block uses the RC input which may be 
asynchronous to WC. 



2.5 MAGNITUDE COMPARATOR 

An 11 -bit magnitude comparator calculated drive 
step direction and number of step pulses be- 
tween present cylinder position and desired posi- 
tion in earlier Winchester controller versions. This 
comparator is not used in the WD42C22C. A 
separate high speed equivalence comparator is 
used to compare ID field bytes when searching for 
a sector ID field. 
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2.6 CRC/ECC GENERATOR AND CHECKER 

The CRC/ECC generator computes and checks 
the cyclic redundancy check characters appended 
to the ID and data fields written on the disk. The 
CRC mode of operation, defined by the SDH 
register (bit 7 set to 0) provides a means of verify- 
ing the accuracy of the data read from the disk but 
does not attempt to correct it. (Bit 7 of the SDH 
register will not implement CRC mode for data 
fields when RLL mode is selected.) The CRC 
polynomial used is: 

X 16 + X 12 +X 5 + 1 

The CRC register is preset to all ones before 
computation starts. 

If the CRC character being generated while read- 
ing the data does not equal the one previously 
written, an error exists. If there is a CRC failure in 
the ID field, an ID not found is indicated by setting 
bit 4 of the error register. If the failure is in the 
data field, bit 6 of the error register is set. 

A 32 bit or 56 bit ECC polynomial may be 
selected instead of the CRC polynomial for the 
data field. The CRC/ECC selection is controller by 
bit 7 of the SDH register when the controller is in 
MFM or NRZ modes. CRC is selected when bit 7 
of the SDH register is in MFM or NRZ modes. 
ECC is selected when bit 7 of the SDH register is 
1 in MFM or NRZ modes. Bit 2 in the set 
parameter command selects either the 32 bit or 
56 bit polynomial. RLL mode defaults to the 56 bit 
polynomial. The CRC or 32 bit ECC options are 
not usable in RLL mode. 

The ECC mode of operation (SDH bit 7 = 1) is 
only applicable to the data field. This feature built 
into the WD42C22C provides the user with the 
ability to detect and correct errors in the data field 
automatically. 

The following is a summary of the parameters 
considered when ECC is used: 

• 1 . SDH register bit 7. 

•2. Read and write command bit 1 (L). 

• 3. Compute correction command. 

• 4. Set parameter command. 

• 5. Error occurred, bit of the status register. 

• 6. On any ECC error the controller stops 
regardless of the T bit. (Refer to the read com- 
mand description.) 



The SDH register bit 7 must be equal to one to 
change from the CRC mode to the ECC mode, for 
MFM and NRZ only. 

When an ECC error is detected, no attempt is 
made to correct it and bit of the status register 
and bit 6 of the error register are set. The user 
now has two choices: 

• 1 . Ignore the error and make no attempt to 
correct it. 

• 2. Use the compute correction command to 
determine the pattern and location of the error, 
and correct it within the user's program. 

When implementing the compute correction com- 
mand, use it before executing commands that 
alter the content of the ECC register. The read, 
write, scan, and format commands can alter the 
syndrome and make correction impossible. If the 
compution correction command determines that 
the error is uncorrectable, then the error bits in the 
status register and error register are set. 

Although ECC generation starts with the first bit of 
the F8 byte in the data ID field, the actual ECC 
bytes produced for the sector are the same as if 
the A1 byte was included. 

The 32-bit ECC polynomial is: 

and is the same one used in the WD1002, 
WD1003, and WD1006 controller boards. The 32- 
bit ECC polynomial has an 11 bit maximum single 
burst correction span. The reverse 32-bit ECC 
polynomial is: 

X 32 + X 30 + X 26 + X 22 + X 15 + X 13 + X 6 + X 4 +1 

The non-detection probability for the 32-bit ECC 
polynomial is: 

2.3(E-10),r t = 516x8,b t = 5 
and the miscorrection probability is: 

1.57(E-5) f r t = 516x8,b t = 5 
The 56-bit ECC polynomial is: 

X 56 + X 52 + X 50 + X 43 + X 41 + X 34 + X 30 + X 26 + 
X 24 + X 8 + 1 

The 56-bit ECC polynomial has a 22 bit maximum 
single burst correction span. 
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The reverse 56-bit ECC polynomial is: 

X 56 + X 48 + X 32 + X 30 + x 26 + x 22 + x 15 + x 13 + 

X 6 + X 4 + 1 

The non-detection probability for the 56-bit ECC 
polynomial is: 

1.39(E-17),r t = 519x8,b t =11 
and the miscorrection probability is: 

5.84 (E-11), ^ = 519x8,^ = 11 
The set parameter command selects the number 
of bits in the correction span, through the use of 
bitO. 

Read and write commands, with the L bit (bit 1 ) 
set to one, are referred to as read long and write 
long commands. With these commands, no ECC 
or CRC characters are generated or checked by 
the WD42C22C. In effect, the four or seven bytes 
are handled as an additional four or seven bytes 
of data which pass through the data buffer. With 
proper use of the write, read long, write long, and 
read commands, a diagnostic routine may be 
developed to test the accuracy of the error correc- 
tion process. 

For CRC/ECC calculations, the CRC/ECC 
register is initialized to all 1's. For CRC/ECC pur- 
poses only, the address mark byte has a value of 
"A1" and is included in the CRC/ECC calcula- 
tions. 



2.7 MFM/RLL ENCODING AND MFM/RLL 
DECODING 

The MFM/RLL encoding section receives 8-bit 
parallel data and generates either MFM or RLL 
write data depending on the K option in the load 
parameter block command. This section operates 
with a write clock having a frequency of the 
desired bit rate. The write clock need not be 
synchronized to read clock (RC). 

Data bytes are written to the drive most significant 
bit first. The MFM/RLL decoding section 
generates 8 bit binary data from MFM or RLL read 
data once an address mark has been detected. 
Table 5 lists the RLL coding rules followed by the 
controller. 



NRZ Data 




RLL Code Word Output 


First Bit Last Bit 


First Bit 


Last Bit 


1 1 


X 


X 


10 


xxxx 


1 


X 


X 


10 


xxxx 


1 


1 


X 


10 


o oxx 


1 





X 


1 


oxx 








X 


10 1 


oxx 





1 


1 





1 000 





1 





10 


100 



TABLE 5. RLL CODING RULES 



When NRZ mode is selected, the MFM/RLL en- 
code and decode logic is bypassed. NRZ read 
data is clocked in on the rising edge of Read 
Clock and NRZ write data is clocked out on the 
rising edge of WC. 



2.8 ADDRESS MARK DETECTOR 

An address mark is a unique 2 byte code placed 
at the beginning of each ID field or data field. A 
series of zero bytes always precedes each ad- 
dress mark. The address mark detector section 
begins searching for an address mark when 
synchronization has been lost after a series of 
zero bytes is detected. The detection of an ad- 
dress mark establishes resynchronization. 

The address mark is composed of a 2 byte se- 
quence. The first byte is used for resynchroniza- 
tion and the second byte specifies ID or data field. 
For the MFM mode, the first byte is an A1i6 byte 
with missing clock (data = A1, clock = 0A). The 
second byte is encoded with normal MFM rules. 
FF through FC and F7 through F4 specify the 
beginning of an ID field and F8 specifies the 
beginning of a data field. 

In RLL mode, the first byte is a unique code which 
violates normal RLL coding rules but does not vio- 
late the 2,7 timing rule. The RLL address mark 
pattern is 1000 0000 1001 0000 (8090ie). The 
second byte is encoded with normal RLL rules. 
FF through FC and F7 through F4 specify the 
beginning of an ID field and F8 specifies the 
beginning of a data field. 
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In NRZ mode, an NRZ A1 byte establishes byte 
synchronization. When the WD42C22C is used to 
control an ESDI (NRZ) drive, the Sector Pulse 
(Address Mark Found) signal will qualify read data 
to prevent false address mark detection. 



2.9 CONTROLLER TO DATA SEPARATOR 
INTERFACE 

The read interface section generates READ 
GATE (RG) from signals sent by the PLA control- 
ler and by the DRUN input. In this system, raw 
read data from the drive is presented to the RD in 
put. RG is low when the controller is not inspect- 
ing read data. When a read command is started 
and a search begins for an address mark, DRUN 
from the data separator is examined. Since each 
address mark should be preceded by ap- 
proximately 12 bytes of zeroes, RG is activated 
when a sequence of zeroes is detected by DRUN 
and read data is examined until either an address 
mark is detected or a non-zero byte which is not 
an address mark is detected. If an address mark 
was detected, and it was preceded by at least 8 
bytes of zeroes, read gate is held high and the ID 
or data field can be read. 

If a non-zero non-address mark byte was 
detected, then RG is dropped for at least 2 byte 
times, allowing the phase lock loop to 
resynchronize with WC, before inspecting DRUN 
input again. If the desired ID field was read, then 
the sector transfer can be made. If a data field 
was detected or if the ID bytes did not match, or if 
an address mark was not preceded by eight bytes 
of zeroes with six coming after RG on, then RG is 
lowered and DRUN is inspected again for a se- 
quence of zeroes. 

Figures 4 illustrates the PLL control sequence for 
the ID field. Figure 5 illustrates the PLL control 
sequence for the data field. 




YES 



ASSERT RG 




DE-ASSERT 
RG 



FIGURE 4. PLL CONTROL (ID FIELD) 
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The write precompensatlon circuitry, in the con- 
troller to the drive interface, reduces the effects 
one bit has on another. There are two parts to 
write precompensation logic, reduced write cur- 
rent (RWC) and shifting of the bits as they are 
written. The RWC is NOT controlled by the drive 
controller. The local microcontroller should specify 
when the write current is reduced by asserting its 
own RWC output. 

The sh ifting of the data bits is controlled by the 
EARLY and LATE outputs. These two outputs 
should be used to delay the output as follows in 
Table 6: 







DELAY 


EARLY 


LATE 





1 


no 
delay 


1 


1 


one unit 
delay 


1 





two units 
delay 



TABLE 6. EARLY AND LATE DELAYS 



The EARLY and LATE outputs are generated ac- 
cording to the rules in Tables 7 (RLL) and 8 (MFM 
orNRZ). 



RLL Coded Data Pattern 


Precomp 


Preceding Comp. 
Bits Bit 


Following 
Bits 


X 1 1 


X 


EARLY 


X 1 


X 


None 


X 1 


001 X 


LATE 


10 1 


10 


None 




TABLE 7. EARLY AND LATE GENERATION 
(RLL MODE) 



FIGURE 5. PLL CONTROL (DATA FIELD) 
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MFM Coding - NRZ Data Pattern 


Precomp 


Preceding 
Bits 


Comp. Following 
Bit Bits 


X X X 1 


■ 1 X X X 


EARLY 


X X X 


1 1 X X X 


LATE 


X X 


1 X X X 


EARLY 


X X 1 


X X X 


LATE 



TABLE 8. EARLY AND LATE GENERATION 
(MFM - NRZ) 



3 .0 INTERFACE PORTS AND TASK 
FILES 



secondary ports. Unless otherwise noted, infor- 
mation regarding the primary ports is identical to 
information on secondary ports.) Table 9 lists the 
port descriptions for this mode. 



HA9 HA2 HA1 HAO 


READ 
PORT 


WRITE 
PORT 


X X 








Read data 


Write data 


X X 





1 


Hardware 
status 


Hardware 
reset 


X X 


1 





Drive con- 
figuration 


Drive 
select 


X X 


1 


1 


NOT 
USED 


DMA and 

interrupt 

control 



TABLE 9. XT PORT DESCRIPTIONS 



3.1 HOST INTERFACE ORGANIZATION 

The WD42C22C's host interface directly connects 
to the IBM XT or IBM AT system bus as well as 
the system bus of any XT or AT compatible. The 
WD42C22C has high current drivers which allow 
it to be directly connected to the system bus. 

The register configuration for the hos t interface is 
dependent on the state of the AT/XT control bit in 
the interface control register which is written by 
the local microcontroller. 

There is an additional slave host mode. In this 
mode, the microcontroller communicates to a 
peripheral device with up to 32 registers through 
the host interface. The slave device can transfer 
data to/from the buffer RAM by using a slave DMA 
scheme such as the WD-BUS mode in the SBIC. 

The sequence that the microcontroller follows to 
transfer data between the buffer RAM and the 
host is defined under the buffer manager descrip- 
tion. 



3.2 XT HOST INTERFACE 

To put the WD42C22C in the XT compatible inter- 
face mode the local microcontr oller resets the 
AT/XT control bit. In this mode, HCS should be 
active when I/O ports 320 (hex) through 323 (hex) 
are addressed. (XT I/O ports 320 through 323 are 
primary ports. XT I/O ports 324 through 327 are 



3.2.1 Read Data Port (HA1 Thru HAO = 0, 
Read) 

The read data port is used to send data and 
status to the host processor. The data read from 
this port comes from the buffer RAM under the 
control of the buffer manager. 



3.2.2 Write Data Port (HA1 Thru 
HAO = 0, Write) 

The write data port is used to send commands 
and data from the host to the drive controller. 
The data is written to the buffer RAM under the 
control of the buffer manager. 



3.2.3 Hardware Status (HA1 Thru 
HAO = 1, Read) 

This port contains the controller hardware status. 
It can be read by the host at any time. Bit 7, bit 6, 
bit 2, and bit 1 are written by the local 
microcontroller. Bit 5, bit 4, bit 3, and bit are 
controlled by internal logic. The bits are defined 
as follows: 



Bit 


7 


6 


5 4 3 2 1 


X 


X 


IRQ DRQ XBSY C/D I/O REQ 
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3.2.3.1 Bit 5 Interrupt Request 

This bit signifies that an interrupt is pending. 
IRQ reflects the state of the INTRQ output. The 
INTRQ pin is tri-stated and the IRQ status bit 
and internal interrupt flip-flop are reset when 
the host disables the interrupt or when the 
WD42C22C is reset, either by the host or by as- 
serting master reset. 



3.2.4 Controller Reset (HA1 Thru 
HA0 = 1, Write) 

When this port is written, regardless of the data 
written, the RESET output is asserted if enabled. 
If the reset has been disabled by the local 
microco ntroller, then writing to this port asserts 
MCINT and the local microcontroller is respon- 
sible for resetting the logic on the drive controller 
board. 



3.2.3.2 Bit 4 Dma Request 

This bit signals that the WD42C22C is ready for a 
DMA transfer to take place. The direction of the 
transfer is determined by the I/O bit. This bit 
reflects the state of the DREQ output. 



3.2.3.3 Bit 3 XT Busy 

This bit indicates that the WD42C22C is busy ex- 
ecuting a command and is unable to accept 
another command. This bit is set by during a 
reset. 



3.2.3.4 Bit 2 Command / Data 

This bit tells the host which type of transfer is 
expected at the read and write data ports. C/D 
set to 1 indicates that a_ command or status 
transfer is expected. C/D set to indicates 
that a data transfer is expected. 



3.2.3.5 Bit 1 Input / Output 

This bit tells the host the_direction of transfer 
for the two data ports. I/O set to 1 indicates 
an input (read) by the host and I/O set to in- 
dicates an output (write) by the host. 



3.2.5 Drive Configuration Information 
(HA1 Thru HAO = 2, Read) 

This register, when read, informs the host about 
the configuration of the drive(s) attached. This 
configuration information is written by the local 
microcontroller. 



3.2.6 Controller Select 

(HA1 Thru HAO = 2, Write) 

When this p ort is w ritten, regardless of the data 
written, the MCINT output is asserted to inform 
the local microcontroller that the controller board 
has been selected. 



3.2.7 DMA and Interrupt Mask 
(HA1 Thru HAO = 3, Write) 

This port enables or disables the DMA and inter- 
rupt to the host. When IRQEN is set to 1, then 
interrupts to the host are enabled. This bit is 
cleared when the WD42C22C is reset. The 
INTRQ line is tri-stated and the host interrupt is 
cleared when the interrupts are disabled. When 
DRQEN is set to 1 , then DMA requests to the host 
are enabled. This bit is cleared when the 
WD42C22C is reset. 




3.2.3.6 Bit Request 

This bit is one of the handshaking signals be- 
tween the host and WD42C22C. When transfer- 
ring data to/from, the WD42C22C's read data and 
write data ports by the host, assertion of this bit 
informs the host that the WD42C22C is ready for 
the transfer. 



Bit 


7 


6 


5 


4 


3 


2 1 


X 


X 


X 


X 


X 


X IRQ DRQ 
EN EN 



ses 
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ABSY 


HA9 


HA2 


HA1 


HAO 


READ 
PORT 


WRITE 
PORT 










AT TASK FILE COPY 



















Read Data 
(16 bits) 


Write Data 
(16 bits) 














1 


Host Error 
Register 


Write Precomp 
Cylinder 











1 





Sector Count 


Sector Count 











1 


1 


Sector Number 


Sector Number 








1 








Cylinder Number 
Low 


Cylinder Number 
Low 








1 





1 


Cylinder Number 
High 


Cylinder Number 
High 








1 


1 





SDH 


SDH 








1 


1 


1 


Host Status 
Register 


Host Command 
Register 


1 





X 


X 


X 


Host Status Register 


INVALID 


CONTROL PORTS 


X 


1 


1 


1 





Alternate Status 
Register 


Fixed Disk 
Register 


X 


1 


1 


1 


1 


Digital Input Register* 


NOT USED 


*Bit 7 is tri- 


stated when the digital input register is 


read to accomodate the floppy disk change status. 



TABLE 10. AT MODE PORT DESCRIPTIONS 



3.3 AT HOST INTERFACE 

To put the WD42C22C in the AT compatible inter- 
face mode, the AT/X T cont rol bit is set by the local 
microcontroller. The HCS chip select should be 
active when I/O ports 1F0i6 through 1F7i6 and 
3F6i6 and 3F7i6 are addressed for primary ad- 
dressing and for I/O ports 170i6 through 177i6 
and 376i6 and 377i6 for secondary addressing. 
Only address signals HA8 through HA3 and AEN 
need to be decoded to generate HCS. Table 10 
describes the ports for AT mode as follows: 



Registers 1 through 7 are an identical copy of the 
drive controller task registers 1 through 7. These 
registers can be read or written by the host only 
when the ABSY status bit is not active. Any at- 
tempt by the host to read the AT task file copy 
while ABSY is active results in the host status 
register being read. The AT task file copy registers 
cannot be written by the host while ABSY is ac- 
tive. 



When port is accessed the IOCS16 output is 
asserted when in AT programmed I/O mode. All 
buffer data transfers are 16 bits. The ECC byte 
transfers in a long mode (read or write) are 8 bit 
transfers. All other register transfers are 8 bits. 
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3.3.1 Error Register 

(HA9, HA2 Thru HAO = 01, Read) 

The error register is read only and contains the 
specific error status pertaining to a command. The 
meaning of the status register bits are as follows: 



Bit 


7 6 


5 4 


3 


2 1 


BB CRC/ 
ECC 


IDNF 





AC TKO DMNF 



3.3.1.1 Bit 7 Bad Block 

A bad block address mark has been detected 
when trying to read or write that sector. The data 
field will not be read or written. 



3.3.1 .2 Bit 6 CRC/ECC Data Field Error 

An uncorrectable ECC error or a CRC error was 
detected in the data field. 



3.3.1.3 Bit 5 Reserved 

Not used, forced to zero. 

3.3.1.4 Bit 4 ID Not Found 

Occurs when cylinder, head, sector, size para- 
meters with a correct ID field CRC cannot be 
found. For read and write sector commands, with 
the retry disable bit reset, this bit indi- 
cates that after 10 index pulses, an auto-scan 
ID and auto-seek, and 10 more index pulses, no 
matching ID field was found. If the retry disable 
bit is set, then no matching ID field was 
found after 2 index pulses; no auto-scan or 
auto-seek is performed. 



3.3.1.5 Bit 3 Reserved 

Not used, forced to zero. 



• 1 . Drive not ready 

• 2. Write fault 

• 3. Illegal command code. 

3.3.1 .7 Bit 1 Track Error 

This bit, when set, indicates an error detect- 
ing Track during a restore. 



3.3.1 .8 Bit Data Address Mark Not Found 

Set if the first two bytes of the data field fol- 
lowing an ID match are not A1 F8. This condition 
is checked for read sector commands only. 



3.3.2 Write Precomp Cylinder Register (HA9, 
HA2 Thru HAO = 01, Write) 

This register is used to control the Reduce Write 
Current (RWC) signal going to the drive. RWC is 
turned on if the present position cylinder number 
is greater than or equal to the 4 times the write 
precomp cylinder number. If the write precomp 
cylinder number is FF16, then the RWC is never 
asserted. 



3.3.3 Sector Count (HA9, HA2 THRU HAO = 
02, Read/Write) 

This register is used in read sector, write sector, 
and format commands to implement multiple sec- 
tor handling with one command. A value of 1 indi- 
cates a single sector transfer, a value of 2 indi- 
cates a 2 sector transfer, and so forth. A value of 
indicates a 256 sector transfer. Sector count is 
decremented and the sector number is incre- 
mented after each sector transfer between the 
buffer and host or drive. 



3.3.4 Sector Number (HA9, HA2 Thru HAO = 
03, Read/Write) 

The sector number register is used to hold the 
number of the desired sector for read and write 
commands. The sector number can range from 
to 255. 




3.3.1 .6 Bit 2 Aborted Command 

Set if command was started and one of the follow- 
ing conditions occurred: 
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3.3.5 Cylinder Number Low And High 
Registers (Cylinder Number Low: HA9, 
HA2 Thru HAO = 04, Read/Write. 
Cylinder Number High: HA9, HA2 Thru 
HAO = 05, Read/Write) 

These registers specify the cylinder number for 
read, write, and format commands. The cylinder 
number may range in value from to 2047. 
Cylinder number low register holds the 8 least sig- 
nificant bits of the desired cylinder number. 
Cylinder number high register holds the three 
most significant bits of the desired cylinder num- 
ber in bits through 2. Bits 3 through 7 are not 
normally used in disk controller boards. These bits 
are latched when writing to this register. This 
means that all 8 bits can be used to transfer infor- 
mation between the host and the local microcon- 
troller. 



3.3.6 SDH Register (HA9, HA2 Thru HAO = 06, 
Read/Write) 

This register is used to specify the desired drive 
and head numbers and to specify CRC or ECC 
mode. 



Bit 


7 


6 


5 4 3 2 10 


CRC/ 
ECC 





SS Drive Head Number 
Number 



3.3.6.1 Bit 7 ECC/CRC Select 

This bit is set for data field ECC mode. It is 
reset for data field CRC mode. 



status. If DS = 1 , then the host receives drive one 
status. 



3.3.6.4 Bits 3 Thru Head Number 

Bits 3, 2, 1 and specify the desired head num- 
ber. 



3.3.7 Host Status Register 

(HA9, HA2 Thru HAO = 7, Read) 

The status register reads only and reflects the 
status of the controller as well as the status of 
certain drive control lines. Some of the status bits 
are controlled by the local microcontroller. Drive 
status comes from two registers in the 
WD42C22C, one for each drive. Bit 4 of the SDH 
register in the AT task file copy controls which of 
the two registers is read when the host reads this 
port. Reading of the status register by the host 
resets INTRQ. The description of the status 
register bits follows: 



Bit 


7 6 


5 


4 3 2 10 


ABSY RDY 


WF 


SC DRQ DWC IDX ERR 



3.3.7.1 Bit 7 AT Busy 

This bit is set to 1 when the controller is ac- 
cessing the disk. ABSY is activated by the 
start of a command (writing into the host com- 
mand register). It is deactivated at end of all 
commands by the local microcontroller. This 
bit is also set during a reset. 



3.3.6.2 Bit 5 Sector Size 

Bit 5 (SS0) is used to select sector size. If SS0 
= 0, then the sector size is 256 bytes and if SS0 
= 1 , then the sector size is 512 bytes. 



3.3.7.2 Bit 6 Drive Ready 

This bit reflects the state of the D RDY drive 
status pin. Any command aborts if DRDY is low. 
This bit is written by the local microcontroller. 



3.3.6.3 Bit 4 Drive Select 

Bit 4 specifies the desired drive number. This bit 
also determines which of the two internal drive 
status registers are read when the host accesses 
the host status register or alternate status 
register. If DS = 0, the host receives drive zero 



3.3.7.3 Bit 5 Write Fault 

This bit reflects the state of the WF drive status 
pin. Any command aborts if WF is high. This bit 
is written by the local microcontroller. 
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3.3.7.4 Bit 4 Seek Complete 

This bit reflects the state of the SC signal com- 
ing from the drive. This bit is written by the 
local microcontroller. 



3.3.7.5 Bit 3 Data Request 

This bit is asserted when the host should be 
transferring data between the RAM buffer and 
host. This bit is controlled by the buffer 
manager. 



3.3.7.6 Bit 2 Data Was Corrected 

This bit indicates that an error in the data 
field was detected and corrected. The buffer 
contains corrected data. This bit is written by 
the local microcontroller. 



3.3.10 Fixed Disk Register 

(HA9, HA2 Thru HAO = E, Write) 

The fixed disk register is used by the host to con- 
trol some of the internal functions of the 
WD42C22C. Bit and bits 4 through bit 7 are 
reserved for future definition. These bits are cur- 
rently not used in the AT protocol but they are 
implemented in the WD42C22C, i.e. the fixed disk 
register passes 8 bits between the host and the 
local microcontroller. The host should write zeroes 
to these bits in AT mode. The fixed disk register is 
coded as follows: 



Bit 


7 


6 


5 


4 3 2 1 














HS3ENRSTIEN 






3.3.7.7 Bit 1 Index 

This bit reflects the state of the INDEX pin. 



3.3.7.8 Bit Error 

This bit indicates that a non-recoverable error 
has occurred. The error register describes the 
error condition when this bit is active. This 
bit is written by the local microcontroller. 



3.3.8 Host Command Register 

(HA9, HA2 Thru HAO = 7, Write) 

The command to be executed is written into this 
register. Writing this register s ets AB SY in the 
status register and asserts the MCINT pin going 
to the local microcontroller. The command latches 
in a register which the local microcontroller reads. 
Writing this register resets INTRQ. 



3.3.9 Alternate Status Register 

(HA9, HA2 Thru HAO = E, Read) 

This register is the same as the host status 
register (7) but mapped at a different address. 
Refer to page 23 for the bit description. 



3.3.10.1 Bit 3 Head Select 3 Enable 

When HS3EN = 1, then HEAD SELECT 3 is as- 
serted by the local microcontroller. When HS3EN 
= 0, then RWC is asserted by the local microcon- 
troller. 



3.3.10.2 Bit 2 Reset 

Writing a 1 to this bit resets the WD42C22C. The 
RESET output is asserted and remains asserted 
until this bit is written back to 0. This bit must 
be on for a minimum of 5.0 |isec. If reset has 
been disabled by the local microcontroller then 
writing a ' 1' to t his bit only resets the 
WD42C22C. RESET is no t assert ed in this case. 
The WD42C22C asserts MCINT and the local 
microcontroller is responsible for resetting the 
drive controller board logic. 




3.3.10.3 Bit 1 Interrupt Enable 

When IEN = 0, then the INTRQ output to the 
host is enabled. When IEN = 1, then the 
INTRQ output to the host is disabled. Disabling 
interrupts does NOT reset an existing interrupt but 
inhibits all further interrupts. Any interrupts pend- 
ing when this bit is set causes the INTRQ output 
to be asserted. A system master reset does NOT 
affect the IEN bit but resets any existing interrupt. 
The internal power qualified reset sets IEN to 0. 
When interrupts are disabled, then the INTRQ pin 
is tri-stated. 
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AAA 
D D D 
7 6 5 


A 
D 

4 


A 
D 
3 


A 
D 
2 


A 
D 

1 


A 
D 



READ PORT 


WRITE PORT 


DISK CONTROLLER TASK FILE 

X X X X X BUSTRISTATE 


NOT USED 


00 1 

















INVALID 


INVALID 


1 
1 
















1 


1 




Error Register 
Sector Count 


PLO Length 
Sector Count 


1 











1 


1 


Sector Number 


Sector Number 


1 
1 
1 












1 
1 
1 





1 




1 




Cylinder Number Low 
Cylinder Number High 
SDH 


Cylinder Number Low 
Cylinder Number High 
SDH 


1 








1 


1 


1 


Status Register 


Command Register 


XT 

1 





1 


1 





1 


Hardware Status 


Hardware Status 


1 





1 


1 


1 





NOT USED 


Drive Configuration 


BUFFER MANAGEF 

110 


t 




Host Buffer Pointer Low 


Host Buffer Pointer Low 


1 
1 


1 
1 












1 


1 




Host Buffer Pointer High 
Host Transfer Count Low 


Host Buffer Pointer High 
Host Transfer Count Low 


1 
1 


1 
1 








1 


1 




1 




Host Transfer Count High 
Disk Buffer Pointer Low 


Host Transfer Count High 
Disk Buffer Pointer Low 


1 
1 


1 

1 






1 
1 




1 


1 




Disk Buffer Pointer High 
Microcontroller RAM Access 


Disk Buffer Pointer High 
Microcontroller RAM Access 


1 


1 





1 


1 


1 


Buffer Status 


Buffer Control 



TABLE 11. LOCAL MICROCONTROLLER REGISTER MAP 



3.3.11 Digital Input Register 

(HA9, HA2 Thru HA0 = F, Read) 

The digital input regi ster is used b y the host to 
determine the state of WRITE GATE and the drive 
selects and head selects. Bit 5 is written by the 
local microcontroller when HS3EN (bit 3 of the 
fixed disk register) is set to zero. Bit 5 comes from 
bit 3 of the host SDH register with HS3EN set to 
one. Bits through bit 4 also come from the host 
SDH register. When this register is read by the 
host, then HD7 (pin 82) is tri-stated. It is coded as 
follows: 



Bit 


7 


6 5 4 3 2 10 


X 


WG HS3/ HS2 HS1 HS0 DS2 DS1 
RWC 
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A A A A A 


A 


A 


A 


A 


READ PORT 


WRITE PORT 


B D D D D 


D 


D 


D 


D 






S 7 6 5 4 
Y 


3 


2 


1 









MISC. 














X 1 1 


1 











Interface Status 


Interface Control 


X 1 1 


1 








1 


Configuration Status Low 


NOT USED 


X 1 1 


1 





1 





Configuration Status High NOT USED 


X 1 1 


1 





1 


1 


Drive Interface Status 


Drive Interface Control 


X 1 1 


1 


1 








Alternate Sector Number 


NOT USED 


AT INTERFACE 












X 1 


1 





1 





AT Control Register 


AT Control Register 


X 1 1 


1 


1 





1 


Drive Status 


Drive Status 


X 1 1 


1 


1. 


1 





Drive 1 Status 


Drive 1 Status 


X 1 1 


1 


1 


1 


1 


Fixed Disk Register 


Digital Input Register 


AT INTERFACE (TASK FILE COPY) 




10 10 











1 


Write Precomp Cylinder 


Error Register 


10 10 








1 





Sector Count 


Sector Count 


10 10 








1 


1 


Sector Number 


Sector Number 


10 10 





1 








Cylinder Number Low 


Cylinder Number Low 


10 10 





1 





1 


Cylinder Number High 


Cylinder Number High 


10 10 





1 


1 





SDH 


SDH 


10 10 





1 


1 


1 


Command Register 
(from Host) 


NOT USED 


SLAVE HOST 














10 





X 


X 


X 


INVALID 


INVALID 


X 1 


1 











INVALID 


Slave Address Port for reads 


X 1 ■ 


1 








1 


Slave Read Data 


Slave Write Data 


X 1 


.1 





1 





INVALID 


Slave Address Port for writes 


X 1 


1 


X 


X 


X 


INVALID 


NOT USED 


X 1 1 


X 


X 


X 


X 


INVALID 


NOT USED 


X 1 1 X 


X 


X 


X 


X 


BUS TRISTATE 


NOT USED 


X 1 X X X 


X 


X 


X 


X 


BUS TRISTATE 


NOT USED 



TABLE 11. LOCAL MICROCONTROLLER REGISTER MAP (CONT'D) 



3.3.11.1 Bit 6 Write Gate On 

This bit reflects the state of the WG output 
pin. 



3.3.11.2 Bit 5 Head Select 3/ 
Reduce Write Current 

This bit reflects the stat e of the HS3/RWC 
drive control output. The RWC bit is written 
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by the local microcontroller. HS3 comes from 
the SDH register bit 3. 



3.3.11 .3 Bit 4, Bit 3, And Bit 2 Head Selects 

Thes e bits reflect the states of the HS2, HSl", 
HSO, and drive control outputs respectively. 
These bits are controlled by SDH register bits 2 
through respectively. 



3.3.11.4 Bit 1 And Bit Drive Selects 

These bits indicate which drive is currently 
being selected by the host. They are controlled 
by the SDH register bit 4. 



3.4 SLAVE HOST INTERFACE 

In slave mode, the WD42C22C host interface can 
be hooked up to a peripheral device such as the 
WD33C93 (SBIC). The microcontroller reads and 
writes the peripheral device through the 
WD42C22C using the ports as follows: 



AAA 


A 


A 


A 


A 


A 


A 


READ 


WRITE 


B D D 


D 


D 


D 


D 


D 


D 


PORT 


PORT 


S 7 6 


5 


4 


3 


2 


1 









Y 


















X 1 








1 











Bus tri- 
state 


Slave 
address 
port for 
reads 


X 1 








1 





1 





Bus tri- 

state 


Slave 
address 
port for 
writes 


X 1 








1 








1 


Slave 

read 

data 


Slave 

write 

data 



The slave peripheral connects to the WD42C22C 
using an ALE type interface. Register reads and 
writes are always 8-bit. The procedure to read or 
write a slave peripheral register is to first write the 
register number to the slave address port before 
the register contents are read or written. This ad- 
dress must always be written before each 
register access even when consecutively access- 
ing the same register two or more times. 



Data transfers between the peripheral device and 
the WD42C22C are WD-bus mode and c an be 
either 8-bit or 16-bit and is controlled by the H16/8 
bit (bit 1 of the auxilliary buffer control register). 
The slave mode is enabled by the HSMB bit (bit 6 
of the auxilliary buffer control register). 



3.5 LOCAL MICROCONTROLLER 
INTERFACE ORGANIZATION 

The local microcontroller controls the host inter- 
face mode (AT or XT) and controls the buffer 
manager and the drive controller. The local 
microcontroller is usually in a sleep state until it is 
told to do something by the as sertion of the 
MCINT output. In the XT mode, MCINT is as- 
serted when t he controller is selected. In the AT 
mode, MCINT is asserted when the host writes to 
the co mmand register. In slave host mode, 
MCINT is asserted when the sl ave pe ripheral 
device asserts its INTRQ signal. MCINT is also 
asserted at the end of each host or disk transfer 
regardless of the interface mode. 

The local microcontroller can have either the 
Intel-type (8051) or the Motorola-type (68HC11) 
interface. The WD42C22C has a built-in MO- 
torola-inTEL (MOTEL) circuit which can sense the 
processor interface type and can therefore be 
directly interfaced to either type processor. 

Table 11 lists the register map for the local 
microcontroller. 



3.6 DISK CONTROLLER TASK FILE 
(AD7 THRU ADO = 20 THRU 27) 



3.6.1 Error Register (AD7 Thru ADO = 21, 
READ) 

The error register reads only and contains the 
specific error status pertaining to a command. 
The meaning of the status register bits are as 
follows: 



Bit 


7 6 5 4 


3 


2 


1 


BB CRC/RIDF IDNF 
ECC 





AC 


DMNF 
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3.6.1.1 Bit 7 Bad Block 

A bad block address mark has been detected 
when trying to read or write that sector. The data 
field is not be read or written. 



3.6.1 .8 Bit Data Address Mark Not Found 

Set if the first two bytes of the data field following 
an ID match are not A1 F8. This condition is 
checked for read sector commands only. 



3.6.1 .2 Bit 6 CRC/ECC Data Field Error 

A CRC error in the data field has been detected 
when in CRC mode. In ECC mode, data errors 
were detected in the data. 



3.6.1.3 Bit 5 Relocation ID Found 

This bit is set if a relocation ID is found after 
detecting the bad block mark in the desired 
sector's ID field. This bit is only valid if the R 
option is used in the set parameter command. 



3.6.1.4 Bit 4 ID Not Found 

Occurs when cylinder, head, sector, size para- 
meters with a correct ID field CRC cannot be 
found. For a scan ID command, this bit is set after 
10 index pulses if the retry disable bit is not set. 
Otherwise, IDNF is set after 2 index pulse if no ID 
was found. For read and write sector commands 
with the retry disable bit set, this bit indicates that 
after 10 index pulses, auto-scan ID and auto- 
seek, and 10 more index pulses, no matching ID 
field was found. If the retry disable bit is set and 
no matching ID field was found after 2 index pul- 
ses, then no auto-scan or auto-seek is performed. 



3.6.2 PLO Length Register 

(AD7 Thru ADO = 21, Write) 

This register is used for two purposes: 

• 1 . To determine the length of the Data PLO 
sync field during write commands and to deter- 
mine the length of the ID PLO sync field dur- 
ing format commands. The contents of this 
register regulates the PLO field size in all data 
coding modes. 

• 2. To load a value in the internal GAP register. 
During the load parameter block command, 
the contents of the lower six bits of the PLO 
length register are transferred to the internal 
GAP register. In hard sector NRZ (ESDI) 
mode, this internal GAP register is used to 
control the delay between the INDEX or SEC- 
TOR pulse and the leading edge of READ 
GATE. In hard sector MFM or RLL mode, this 
internal GAP register is used to control the 
delay between the INDEX or SECTOR pulse 
and the falling edge of the internally generated 
DRUN signal. In hard sector MFM or RLL 
mode, RG is asserted 2 byte times after 
INDEX or SECTOR. This GAP register is al- 
tered by loading the desired GAP register 
value into the PLO length register and then is- 
suing a load parameter block command. 




3.6.1.5 Bit 3 Reserved 

Not used, forced to zero. 



3.6.3 Sector Count (AD7 Thru ADO = 22, 
Read/Write) 



3.6.1 .6 Bit 2 Aborted Command 

Set if command was started and one of the follow- 
ing conditions occurred: 

• 1 . Drive not ready 

• 2. Write fault 

• 3. Illegal command code. 



3.6.1.7 Bit 1 Reserved 

Not used in WD42C22C, forced to zero. 



Bit 



NUMBER OF SECTORS/GAP VALUE 
SECTOR WITH BAD BLOCK 



This register is used for three purposes: 
• 1 . The sector count register is used in read 
sector, write sector, and format commands to 
implement multiple sector handling with one 
command. A value of 1 indicates a single sec- 
tor transfer, a value of 2 indicates a 2 sector 
transfer, and so forth. A value of indicates a 
256 sector transfer. Sector count decrements 
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and sector number increments after each sec- 
tor transfer to or from the buffer. 

• 2. To load a value into the internal gap value 
register. During the load parameter block com- 
mand the contents of this register are trans- 
ferred into an internal gap value register. This 
gap value register specifies the data byte writ- 
ten into the gaps during format commands. 

3. To specify to the microcontroller the sector 
number where a bad block bit was detected if 
relocation ID searches are enabled. If the R 
option is set in a set parameter command, 
then during read and write commands if a bad 
block is detected, the WD42C22C searches 
for a special ID field containing relocation infor- 
mation. When the command terminates due to 
a bad block, then the sector number of the sec- 
tor with the bad block is returned to the micro- 
controller in this register. This is true whether 
or not the relocation information is detected. 



3.6.5 Cylinder Number Registers 
(Cylinder Number Low: 
AD7 Thru ADO = 24, Read Write 
Cylinder Number High: 
AD7 Thru ADO = 25, Read/Write) 

This register has two functions: 

• 1 . To specify the cylinder number for read, 
write, and format commands. The cylinder 
number may range in value from to 2047. 

• 2. The cylinder number register is used during 
a load parameter block command to specify 
the desired sector size if a non-standard sec- 
tor size is desired and to specify the offset for 
a write ID command. To load the internal sec- 
tor size register, write in the desired sector 
size into the cylinder registers. Next, issue a 
load parameter block command. Set U=1 to 
enable the programmable sector size or 
programmable write ID offset. 



3.6.4 Sector Number 

(AD7 Thru ADO = 23, Read/Write) 



Bit 


7 


6 5 4 3 2 1 





SECTOR NUMBER / GAP SIZE 



The sector number register has three uses: 

• 1 . To hold the number of the desired sector for 
read and write commands. The sector number 
can range from to 255. 

• 2. To control the Gap 1 and Gap 3 sizes 
during format commands. The sector number 
holds the number of gap bytes minus three for 
format (number of gap bytes minus six for 
NRZmode). 

• 3. To load a value into the internal pad value 
register. During the load parameter block com- 
mand, the contents of this register are trans- 
ferred into an internal pad value register. This 
pad value register specifies the data byte writ- 
ten into the ID and DATA pads during format 
and write commands 



3.6.6 Cylinder Number Registers 
(Cylinder Number Low: 
AD7 Thru ADO = 24, Read/Write 
Cylinder Number High: 
AD7 Thru ADO = 25, Read/Write) 

Cylinder number low register holds the 8 least 
significant bits of the desired cylinder number or 
the 8 least significant bits of the desired sector 
size. 

Cylinder number high register holds the three 
most significant bits (bits through 2) of the 
desired cylinder number or the three most sig- 
nificant bits of the desired sector size. Bits three 
through seven of the cylinder number high 
register are not used and must be set to zero. 



3.6.7 SDH Register (AD7 Thru ADO = 26, 
Read/Write) 

This register is used to specify the desired drive 
and head numbers and to specify CRC or ECC 
mode. There are two SDH modes available, three 
or four bit head number. Three bit head mode is 
the default after a master reset. Setting the H bit 
in the set parameter command engages the four 
bit head mode. 
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3.6.7.1 SDH Register, Three-Bit Head Number 3.6.7.5 



Bit 


7 6 


5 


4 


3 


2 1 


CRC/ SS1 
ECC 


sso 








Head # 



3.6.7.2 SDH Register, Four-Bit Head Number 



Bit 


7 6 


5 


4 


3 2 1 





CRC/ SS1 
ECC 


SSO 





Head# 





3.6.7.3 Bit 7 ECC/CRC Select 

This bit is set for data field ECC mode. It is reset 
for data field CRC mode. In RLL mode, this bit is 
ignored. RLL mode always uses 7-byte ECC. The 
CRC/ECC flag bit is not written on the disk at 
format time. The bad block flag is written on the 
disk in its place. 



3.6.7.4 Bit 6 and Bit 5 Sector Size 

Bits 6 and 5 contain sector size bits. These bits 
are written on the disk at format time. These bits 
should be if programmable sector size is used. 
These bits are reserved for special flags in 
programmable sector size mode. The possible 
sector sizes and their selection codes are as fol- 
lows: 



SS1 



SSO 



Sector Size 












1 


1 





1 


1 



256 byte data field 
51 2 byte data field 
1024 byte data field 
128 byte data field 



The sector sizes can be optionally specified to 
be any value between 100 and 2048 bytes by 
using the load parameter block command. The 
user is responsible for validating the effectiveness 
of the ECC for sector sizes over 1056 bytes. 



Bit 4 and Bit 3 Reserved 
Bit 4 Drive Number Reserved 



Reserved. Set to 0. 



3.6.7.6 Bit 2, Bit 1, And Bit 

Three Bit Head Number 
Bit 3, Bit 2, Bit 1, And Bit 
Four Bit Head Number 

Bits 2, 1, and specify the desired head 
number in the three bit mode. Bits 3, 2, 1 , and 
specify the desired head number in four bit mode. 
The local microcontroller is responsible for 
outputting these bits to the drive. 

NOTE 

These bits are written on the disk at format 
time. The SDH byte written in the ID field during 
a format command is NOT the same as the SDH 
register. The SDH format byte is shown 
below: 



3.6.7.7 SDH ID Field Format Byte 
(Three Bit Head Mode) 



Bit 


7 6 


5 


4 


3 


2 1 


Bad SS1 
Block 


SSO 








Head # 




3.6.7.8 SDH ID Field Format Byte 
(Four Bit Head Mode) 



Bit 


7 6 


5 


4 


3 2 


1 





Bad SS1 
Block 


SSO 





Head# 







3.6.8 Status Register (AD7 Thru 
ADO = 27, Read) 

The status register is read only and reflects the 
status of the controller as well as the status of 
certain drive control lines. If command in progress 
(bit 1 ) is set then no other register reads are valid 
and none of the other register bits are valid. The 
status register contents are returned for any read 
and all writes are disabled. The description of the 
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status register bits follows: 



Bit 


7 6 


5 


4 


3 


2 


1 


RDY 


WF 


1 








ERR 



3.6.8.1 Bit 7 Always 

This bit is always zero when the microcontroller 
has access to this status register. 



3.6.8.8 Bit Error 

This bit indicates that a non-recoverable error has 
occurred. The error register describes the error 
condition when this bit is asserted. 

Drive ready and write fault bits reflect the state of 
their associated input pins. The states of these 
status register bits are latched at the end of the 
command and are unlatched after the first status 
register read. Reading the status register results 
in the disk controller interrupt being reset. 



3.6.8.2 Bit 6 Drive Ready 

This bit reflects the status of the DRDY. Any com- 
mand aborts if DRDY is low. 



3.6.8.3 Bit 5 Write Fault 

This bit reflects the state of the WF pin. Any com- 
mand aborts if WF is high. 



3.6.8.4 Bit 4 Always 1 

This bit reflects the state of the SC input to the 
drive controller. This signal is internally tied to 
Vdd. 



3.6.8.5 Bit 3 Always 

This bit reflects the state of the BDRQ signal that 
goes between the drive controller and the buffer 
manager. It is always zero when the 
microcontroller has access to this status register. 

3.6.8.6 Bit 2 Not Used 

Forced to 



3.6.8.7 Bit 1 Always 

This bit reflects the state of the command in 
progress signal in the drive controller. It is always 
zero when the microcontroller has access to this 
status register. 



3.6.9 Command Register 

(AD7 Thru ADO = 27, Write) 

The command to be executed is written into this 
register. Writing this register sets the internal 
BUSY and CIP signals and causes the controller 
to start executing the desired command. Writing 
this register resets the disk controller interrupt 
(DCI bit in the interface status register). 



3.7 XT Interface Ports 



3.7.1 XT Host Hardware Status 

(AD7 Thru ADO = 2D, Read/Write) 

Bits 7, 6, 2, and 1 of this register are written by 
the local microcontroller and read by the host. The 
other bits reflect the state of certain hardware sig- 
nals. This register is readable and valid in all host 
modes. 



Bit 


7 


6 


5 4 3 2 10 


1 


1 


IRQ DRQ XBSYC/D I/O REQ 



3.7.1 .1 Bits 6 And 7 Undefined 

These bits are currently undefined in the XT 
protocol and read as 1 . 



3.7.1 .2 Bit 5 Interrupt Request 

This bit reflects the state of the INTRQ output. 
This bit can NOT be written by the microcontrol- 
ler. 
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3.7.1.3 Bit 4 DMA Request 

This bit reflects the state of the DREQ output. 
This bit can NOT be written by the microcontroller. 



3.7.1.4 Bit 3 XT Busy 

This bit reflects the state of the internal XT 
BUSY flipflop. This bit is set by during a reset and 
is set when the WD42C22C is selected in XT 
mode. This bit can NOT be written by the micro- 
controller. 



3.7.1 .5 Bit 2 Command / Data 

This bit tells the host which type of transfer is 
expected at the read data and write data ports. 
C/D = 1 indicates that acommand or status trans- 
fer is expected and C/D = indicates that a data 
transfer is expected. This bit is written by the 
microcontroller. 



3.7.1.6 Bit 1 Input / Output 

This bit tells the host the direction of transfer for 
the two data ports. I/O = 1 indicates an input 
(read) by the host and I/O = indicates 
an output (write) by the host. This bit is written by 
the microcontroller. 



3.7.1.7 Bit Request 

This bit indicates the state of the internal host 
transfer enable. This bit is active when the buffer 
manager is transferring data between the RAM 
and the host. This bit can NOT be written by the 
microcontroller. This bit is identical to the DRQ in 
the drive zero status and drive one status 
registers used in AT mode. 



3.7.2 Host Drive Configuration 
(AD7 Thru ADO = 2E, Write) 

This register is used to write the drive configura- 
tion information that is read by the host. 



3.7.3 Buffer Manager Registers 

(AD7 Thru ADO = 30 Thru 37) 

Host Buffer Pointer Low 

(AD7 Thru ADO = 30, Read/Write) 

Host Buffer Pointer High 

(AD7 Thru ADO = 31 , Read/Write) 



Bit 


7 


6 5 4 3 


2 1 





LEAST SIGNIFICANT BYTE OF HOST 
BUFFER POINTER 




Bit 


7 


6 5 4 3 


2 1 








MOST SIGNIFICANT BITS OF HOST 
BUFFER POINTER 



The host buffer pointer low register contains the 
least significant byte of the host buffer pointer. 
The host buffer pointer high register contains the 
seven most significant bits of the host buffer 
pointer. The host buffer pointer is used as the 
base address for the internal host buffer counter. 
The contents of the host buffer pointer registers 
are transferred to the host buffer pointer counter 
under the control of the buffer control register. 

When the AHBP bit is set in the control register, 
then the pointer register is transferred to the 
pointer counter when the transfer counter reaches 
zero. If the transfer count is already zero, then the 
transfer occurs immediately. This allows a pend- 
ing transfer to be queued behind the current 
transfer. When the pointer is transferred to the 
counter, the AHBP buffer status bit resets. 



3.7.4 Host Transfer Count Low 

(AD7 Thru ADO = 32, Read/Write 
Host Transfer Count High 
(AD7 Thru ADO = 33, Read/Write) 

The host transfer count low register contains the 
least significant byte of the host transfer count. 
The host transfer count high register contains the 
most significant bits of the host transfer count. 
The transfer count controls the number of bytes 
that are to be transferred on the host interface. 
The transfer count register is transferred to the 
internal transfer counter at the same time that the 
host buffer pointer register is transferred to the 
host buffer pointer counter. The transfer counter is 
12 bits long which gives a maximum transfer 
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count of 4095 bytes. 



Bit 


7 6 5 4 


3 2 10 


LEAST SIGNIFICANT BYTE OF HOST 
TRANSFER COUNT 




Bit 


7 6 5 4 


3 2 1 





MS BITS OF 
HOST TRANSFER 
COUNT 



3.7.5 Disk Buffer Pointer Low 

(AD7 Thru ADO = 34, Read/Write) 

Disk Buffer Pointer High 

(AD7 Thru ADO = 35, Read/Write) 

The disk pointer low register contains the least 
significant byte of the disk buffer pointer. The disk 
pointer high register contains the seven most sig- 
nificant bits of the disk buffer pointer. The disk 
buffer pointer is used as the base address for the 
internal disk buffer counter. The contents of the 
disk buffer pointer registers are transferred to the 
disk buffer pointer counter under the control of the 
buffer control register. When the ADBP bit is set in 
the control register, then the pointer is transferred 
to the counter when the drive controller sets DRQI 
to 1 (bit 1) in the interface status register (38i6). 
This allows a pending transfer to be queued be- 
hind the current transfer. When the pointer 
register is transferred to the counter, the ADBP bit 
in the buffer status resets. If ADBP=0 when the 
drive controller sets DRQI to 1, then the drive 
controller stops transferring data to the buffer and 
discontinues the command until ADBP sets. 



Bit 


7 6 5 4 3 2 


1 





LEAST SIGNIFICANT BYTE OF 
DISK BUFFER POINTER 


Bit 


7 6 5 4 3 2 


1 





MOST SIGNIFICANT BYTE OF 
DISK BUFFER POINTER 



3.7.6 Microcontroller RAM Access Port (AD7 
Thru ADO = 36, Read/Write) 

This port is used by the local microcontroller to 
access the buffer RAM. Accesses to this port go 
through the drive controller's FIFO. These acces- 
ses are enabled by the MAC bit in the drive inter- 
face control register. The DRWB bit in the buffer 
manager control register controls the direction of 
the accesses. 



3.7.7 Buffer Control Register 

(AD7 Thru ADO = 37, Write) 

This register is used to control the buffer 
manager. 



Bit 


7 


6 5 4 


AT/XT RDCFG RXC AHBP 


3 


2 1 


HRWB DRWB BDEN ADBP 



3.7.7.1 Bit 7 AT / XT INterface Control 

This bit, along with HSMB, in the auxilliary 
buffer control register, controls the host interface 
type. If AT/XT = 0. then the interface is XT type if 
HSMB = 0. If AT/XT = 1, then the interface is AT 
type if HSMB = 0. This bit has no meaning if 
HSMB = 1 . The RESET input and the host soft 
reset does not affect this bit. 



3.7.7.2 Bit 6 Read Configuration 

When this bit is set, all buffer address outputs 
are placed in a medium impedence state with 
each buffer address pin having a 180 |iA current 
source pulldown. The buffer manager should be 
idle when this mode is enabled. This mode is 
used to read configuration switch information. The 
microcontroller should wait 100 jusec after setting 
this bit before readi ng the c onfiguration registers. 
This bit resets when RESET is asserted. 



3.7.7.3 Bit 5 Reset Transfer Counter 

When this bit is set, the internal transfer counter 
and the host FIFO pointers reset. This bit resets 
after the transfer counter and FIFO reset. 
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3.7.7 A Bit 4 Arm Host Buffer Pointer 

Writing a 1 to this bit, sets an internal latch. Writ- 
ing a to this bit has no effect. When this bit is 
set, then when the internal transfer counter 
reaches zero the host buffer pointer is transferred 
to the internal host buffer counter and the host 
transfer count is transferred to the internal transfer 
counter. This bit is reset by the WD42C22C after 
the host pointer and cou nt regist ers are trans- 
ferred. This bit resets when RESET is asserted. 



3.7.7.5 Bit 3 Host Read / Write 

This bit controls the direction of the host data 
transfers. It is used internally to control the direc- 
tion of the FIFO. When HRWB = 0, then the host 
writes to the WD42C22C. When HRWB = 1 , then 
the host reads from the WD42C22C. 



the next byte read or written by the microcontroller 
will be at the new address loaded into the disk 
buffer pointer. 



3.7.8 Buffer Status Register 

(AD7 Thru ADO = 37, Read) 

This register reflects the status of the buffer 
manager logic. 



Bit 


7 


6 


5 


4 


AT/XT 


RDCFG 


RXC 


AHBP 


3 


2 


1 





HRWB 


DRWB 


BDEN 


ADBP 



3.7.7.6 Bit 2 Disk Read / Write 

This bit controls the direction of the disk or local 
microcontroller data transfers. It is used internally 
to control the direction of the disk FIFO. When 
DRWB = 0, then the disk controller or local 
microcontroller writes to the buffer RAM. When 
DRWB = 1, then the disk controller or local 
microcontroller reads from the buffer RAM. When 
the microcontroller accesses the buffer RAM, then 
this bit should be written before the ADBP bit is 
set. 



3.7.7.7 Bit 1 Burst DMA Enable 

When BDEN = 1 and HDMA = 1 in the auxilliary 
buffer control register, then burst DMA transfers 
are enabled on the host interface. 



3.7.7.8 Bit Arm Disk Buffer Pointer 

Writing a 1 to this bit, sets an internal latch. Writ- 
ing a to this bit has no effect. When this bit is 
set, then the disk buffer pointer is transferred to 
the internal disk buffer counter when the drive 
controller sets the BDRQ interrupt. This bit also 
enables the disk controller to continue to the next 
sector. This bit is reset by the WD42C22C after 
the pointer registers have been transferred. 
When the disk controller port is used by the local 
microcontroller to access the buffer RAM, then 
setting this bit resets the disk FIFO pointers and 



3.7.8.1 Bit 7 AT / XT Interface Mode 

This status bit reflects the state of the AT/XT con- 
trol bit defined above. 



3.7.8.2 Bit 6 Read Configuration 

This bit reflects the state of the read configuration 
control bit defined in the buffer manager control 
register. 



3.7.8.3 Bit 5 Reset Transfer Counter 

This bit reflects the state of the RXC control bit 
defined in the buffer control register. 



3.7.8.4 BIT 4 Host Buffer Pointer Armed 

This bit reflects the state of the AHBP control bit 
defined in the buffer control register. 




3.7.8.5 Bit 3 Host Read / Write 

This bit reflects the state of the HRWB control bit 
defined in the buffer control register. 



3.7.8.6 Bit 2 Disk Read / Write 

This bit reflects the state of the DRWB control bit 
defined in the buffer control register. 
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3.7.8.7 Bit 1 Burst DMA Enable 

This bit reflects the state of the BDEN control bit 
defined in the buffer control register. 

3.7.8.8 Bit Disk Buffer Pointer Armed 

This bit reflects the state of the ADBP control bit 
defined in the buffer control register. 



3.7.9 AUxilliary Buffer Control Register (AD7 
Thru ADO = 2F, Write) 

This register is used for additional control of the 
buffer manager and host interface. 



Bit 


7 


6 


5 


4 


HDMA 


HSMB 


BCNT 


IDD 


3 


2 


1 





DSEL 


X 


H16/8 


SCKS 



3.7.9.1 Bit 7 Host DMA 

This bit controls the host data transfers to/from 
the buffer RAM. If HDMA = 1, then the data is 
transferred to the host via DMA regardless of the 
host interface selected. If HDMA = 0, the default, 
then data is transferred via programmed I/O. 



3.7.9.2 Bit 6 Host Slave /Master 

When HSMB = 0, the default, then the host is a 
master which drives the WD42C22C in either XT 
or AT type interface. When HSMB = 1 , then the 
host is a slave device which is controlled by the 
local microcontroller. The slave device can be 
addressed in either ALE or indirect mode. The 
SBIC is an example of a device which can be 
connected to the WD42C22C. The ALE mode 
supports up to 32 registers in the slave device. 
Data transfers occur via WD-BUS mode if HDMA 
= 1 and is an 8-bit transfer if H16/8 = and a 
16-bit transfer if H16/8 = 1. This bit resets upon 
power-up but not affected by RESET. 



3.7.9.3 Bit 5 Burst Continuous 

This bit, along with the HDMA bit, and the BDEN 
bit in the buffer control register control the burst- 
ing of data during DMA transfers. If BCNT = 
1, HDMA = 1, and BDEN = 1, then the 
WD42C22C DMAs data continuously as long as 
the FIFOs can keep up. If BCNT = 0, HDMA = 1, 
and BDEN = 1, then the WD42C22C DMAs data 
in 8-byte or 16-byte maximum length bursts, for 8 
and 16 bit host data bus width, respectively. 



3.7.9.4 Bit 4 Intelligent Drive Decode 

When IDD = 1, then the controller is assumed to 
be on an i ntelligen t drive. The HDO-15, INTRQ, 
and DREQ/IOCS1 6 outputs are always tri-stated if 
the drive is not selected. If IDD = 0, the default, 
then the outputs are controlled normally. This b it 
resets upon power up but not affected by RESET. 



3.7.9.5 Bit 3 Drive Select 

This bit is used when IDD = 1 to control drive 
selection. If AT/XT =1, then the drive is con- 
sidered selected when SDH register bit 4 equals 
DSEL. If AT/XT = 0, then the drive is considered 
selected if DSEL = 1 and not selected if DSEL = 
0. This bit resets upon power-up but not affected 
by RESET. 



3.7.9.6 Bit 1 Host 16/8 Bit 

This bit controls the width of the data transfers on 
the host side. If H 16/8 = 0, then the host data 
transfers are 8-bit. If H16/8 = 1, the host data 
transfers are 1 6-bit . This bi t resets upon power up 
but not affected by RESET. 



3.7.9.7 Bit Synchronous Clock Switch 

This bit is used to control the clocking of the drive 
controller so that ESDI drives can be changed or 
data rates can be changed without the need for 
external clock deglitching. When SCKS =1, the 
default, then the WD42C22C synchronously 
switches the drive controller to the internal buffer 
clock (BCLK). When SCKS = 0, the WD42C22C 
switches the drive controller back to WCLK. The 
switch occurs only if both clocks are present. The 
CKSRC status bit defined below in dicates 
whether or not the switch occured. When RESET 
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is asserted, the buffer clock clocks the drive con- 
troller during the reset and SCKS is set. The 
microcontroller must switch the clock source to 
the WCLK input prior to issuing any commands to 
the drive controller. 



3.7.10 Auxilliary Buffer Status Register (AD7 
Thru ADO = 2F, READ) 

This register gives additional status of the buffer 
manager and host interface. 



Bit 


7 


6 


5 


4 


HDMA 


HSMB 


BCNT 


IDD 


3 


2 


1 





DSEL 


CKSC 


H16/8 


SCKS 



3.7.10.1 Bit 7 Host DMA 

This bit reflects the state of the HDMA control bit 
defined in the auxilliary buffer control register. 



3.7.10.2 Bit 6 Host Slave / Master 

This bit reflects the state of the HSMB control bit 
defined in the auxilliary buffer control register. 



3.7.10.3 Bit 5 Burst Continuous 

This bit reflects the state of the BCNT control 
bit defined in the auxilliary buffer control 
register. 



3.7.10.6 Bit 2 Clock Source 

This bit indicates the source of the drive controller 
clock. If CKSRC = 1 and SCKS = 1 , then the drive 
controller is being clocked by the buffer clock 
(BCLK). If CKSRC = and SCKS = 0, then the 
drive controller is clocked by WCLK. If CKSRC = 
1 and SCKS = or CKSRC = and SCKS = 
1, then the clock source is undefined. CKSRC 
should not be checked until at least 10 clock 
periods after the SCKS has been written. The 
slower of BCLK and WCLK should be used in 
determining this delay. 



3.7.10.7 Bit 1 Host 16/ 8 

This bit reflects the state of the H16/8 control bit 
defined in the auxilliary buffer control register. 



3.7.10.8 Bit Synchronous Clock Switch 

This bit reflects the state of the SCKS control bit 
defined in the auxilliary buffer control register. 



3.7.11 Interface Status Register 

(AD7 THRU ADO = 38, READ) 

This register is used to indicate the status of the 
WD42C22C. The bits are defined as follows: 



Bit 


7 


6 


5 


4 


MINT 


DCGI 


RSTI 


FEI 


3 


2 


1 





DCI 


HPRI 


DRQI 


CWSI 




3.7.10.4 Bit 4 Intelligent Drive Decode 

This bit reflects the state of the IDD control bit 
defined in the auxilliary buffer control register. 



3.7.10.5 Bit 3 Drive Select 

This bit reflects the state of the DSEL control bit 
defined in the auxilliary buffer control register. 



3.7.11.1 Bit 7 Microcontroller 
interrupt 

This bi t is hig h if the MCINT output pin is as- 
serted. MCINT is the logical OR of seven sources: 

• 1 . A host SDH register write 

• 2. A host soft reset 

• 3. A FIFO error 

• 4. The disk controller interrupt signal 

• 5. The host transfer count interrupt flip-flop 

• 6. The disk controller BDRQ signal 

• 7. The command write/select interrupt flip-flop. 
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If any of the bits 6 through are set, then the 
MClNTbitishlgh. 



3.7.11.2 Bit 6 Drive Change Interrupt 

This bit sets when the host writes a new value to 
the SDH register bit 4 when AT mode is selected. 

3.7.11.3 Bit 5 Soft Reset Interrupt 

This bit sets if the host initiates a soft reset. This 
bit resets by writing the proper bit in the interface 
control register. 



3.7.11.4 Bit 4 FIFO Error Interrupt 

This bit sets if a FIFO overrun or underrun condi- 
tion occurs during host or disk transfers. It resets 
by writing the proper bit in the interface control 
register. 



3.7.11.5 Bit 3 Disk Controller 
interrupt 

This bit reflects the state of the disk controller 
interrupt signal. This interrupt occurs at the end of 
a command. This bit resets either when the disk 
controller status (port 27i6) is read or when the 
disk controller command (port 27i6> register is 
written. 



in the buffer control register, 37i6) when this bit 
first goes from to 1, then DRQI and MCINT is 
not reset until after the microcontroller writes 
ADBP=1. 



3.7.11.8 Bit Command Write / Select / Slave 
Interrupt 

This bit informs the local microcontroller that a 
command has been written if the WD42C22C is 
in AT mode, that the WD42C22C has been 

selected if it is in XT mode, or that the slave host 
device has issued an interrupt if in slave host 
mode. (Asserts INTRQ. A slave interrupt only trig- 
gers on rising edge of INTRQ.) This bit resets by 
writing the proper bit in the interface control 
register. 



3.7.12 Interface Control Register 
(AD7 Thru ADO = 38, Write) 

This register is used to control various parts of the 
WD42C22C. The bits are defined as follows: 



Bit 


7 


6 


5 


4 


SIRQ 


RDCI 


RSRI 


RFEI 


3 


2 


1 





RBSY 


RHRI 


RDQI 


RCWS 



3.7.11.6 Bit 2 Host Pointer Ready 
interrupt 

This bit reflects the state of the host transfer count 
interrupt flip-flop. This interrupt sets when the host 
transfer counter reaches zero and the FIFO is 
empty if the host pointer is not armed. It is also 
set when the host pointer pipeline register is 
loaded into the host pointer counter. It resets by 
writing the proper bit in the interface control 
register. 



3.7.12.1 Bit 7 Set Interrupt 

Writing a 1 to this bit generates a host interrupt if 
interrupts are enabled. 



3.7.12.2 Bit 6 Reset Drive Change 
Interrupt 

Writing a 1 to this bit resets the host SDH write 
interrupt flip-flop. 



3.7.11.7 Bit 1 Disk BDRQ Interrupt 

This bit reflects the state of the disk controller 
BDRQ signal. It sets when the disk controller 
starts a transfer between the disk controller and 
the sector buffer. It resets by writing the proper bit 
in the interface control register. If ADBP = (bit 



3.7.1 2.3 Bit 5 Reset Soft Reset 
interrupT 

Writing a 1 to this bit resets the soft reset interrupt 
flip-flop. In AT mode, the microcontroller must wait 
for the RST bit (2) in the FDR register (3Fi 6) to be 
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reset by the host before this interrupt can be 
reset. 



3.7.12.4 Bit 4 Reset FIFO Error 
interrupt 

Writing a 1 to this bit resets the FIFO error inter- 
rupt flip-flop. 



3.7.12.5 Bit 3 Reset Busy 

Writing a 1 to this bit resets the BSY status bit in 
the hardware status register if XT mode is 
selected or it resets the ABSY status bit in the 
host status register if AT mode is selected. In AT 
mode, this bit should only be set at the very end 
of a command after the last DRQ is asserted to 
the host. Internal logic handles ABSY during buff- 
er transfers to the host. 



3.7.12.6 Bit 2 Reset Host Pointer Ready 
Interrupt 

Writing a 1 to this bit resets the host pointer ready 
interrupt flip-flop. 



3.7.12.7 Bit 1 Reset Disk BDRQ Interrupt 

Writing a 1 to this bit resets the disk BDRQ inter- 
rupt flip-flop. 



3.7.12.8 Bit Reset Command Write / Select / 
Slave Interrupt 

Writing a 1 to this bit resets the command 
write/select/slave interrupt flip-flop. 



3.7.13 Configuration Status Registers 
(Low: AD7 Thru ADO = 39, Read 
High: AD7 Thru ADO = 3A, Read) 

The configuration status registers are used to 
read the configuration jumpers on buffer address 
pins. When in read configuration mode, the buffer 
address lines have 300 fxA current source 
pulldowns enabled. If there is no external pullup 
resistor on the buffer address line, then the state 
of the line is read as a 0. If a 13K external pullup 
resistor is connected to a buffer address line, 
then the state of the line is read as a 1. The 



configuration registers should not be read until 
100 jisec after enabling read configuration mode, 
to allow the buffer address line voltages to reach 
their proper value. Register contents are un- 
defined if not in read configuration mode. 



Configuration status low 
Bit 



BA7THRUBA0 

Configuration status high 
Bit 



BA14THRUBA8 



3.7.14 Drive Interface Status 

(AD7 Thru ADO = 3B, Read) 

This register gives status information for the drive 
controller. It is coded as follows: 



Bit 


7 


6 


5 


4 


3 


2 


1 


RDC 


DRDY WF 


HDS 


MACDROIPOLDSN 



3.7.14.1 Bit 7 Reset Drive Controller 

This bit reflects the state of the reset drive control- 
ler control bit defined in the drive interface control 
register. 



3.7.14.2 Bit 6 Drive Ready 

This bit is set if the DRDY input is asserted by. the 
drive. It can always be read by the local 
microcontroller regardless of the state of disk con- 
troller busy. 



3.7.14.3 Bit 5 Write Fault 

This bit is set if the WF input is asserted by the 
drive. It is always valid. 
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3.7.14.4 Bit 4 Host Drive Select 

This bit reflects the state of bit 4 of register 46-ia, 
the host copy of the SDH register. It is used by the 
host in AT mode as a drive select. If HDS = 0, 
then drive 1 is selected. If HDS = 1 , then drive 2 is 
selected. This bit is always accessable to the 
microcontroller regardless of the state of ABSY. 



3.7.14.5 Bit 3 Microcontroller Access Control 

This bit reflects the state of the microcontroller 
access control bit defined in the drive interface 
control register. 



3.7.14.6 Bit 2 Disable Reset Output 

This bit reflects the state of the disable reset out- 
put control bit defined in the drive interface control 
register. 



3.7.14.7 Bit 1 Input Polarity 

This bit reflects the state of the input polarity con- 
trol bit defined in the drive interface control 
register. 



3.7.15.2 Bit 3 Microcontroller Access Control 

When this bit is set, the microcontroller is tied to 
the buffer RAM through the disk controller's port. 
The microcontroller can then read or write the 
buffer by reading from or writing to the RAM ac- 
cess port (36i6). The DRWB bit in the buffer 
manager control port should be set to the proper 
state before this bit is set. When MAC = 1, then 
the disk controller task file (registers 21 16 through 
27i6) cannot be accessed by the microcontroller, 
if the microcontroller writes to these registers 
when MAC = 1 , then the disk con troller m ay not 
act properly. This bit resets when RESET is as- 
serted. The proper sequence for the 
microcontroller to read/write the RAM is defined 
under the buffer manager description. 



3.7.1 5.3 Bit 2 Disable Reset Output 

When this bit is set, all ho st initiat ed soft resets 
are disabled. Instead of the RESET li ne bein g as- 
serted on soft reset, only the MCINT line 
is asserted. It is the responsibility of the local 
microcontroller to properly reset the board 
hardware when this bit is set. This bit resets only 
during power-up. 



3.7.14.8 Bit Disable Sector Number 

This bit reflects the state of the disable sector 
number control bit defined in the drive interface 
control register. 



3.7.15 Drive Interface Control 

(AD7 Thru ADO = 3B, Write) 

This register is used to control the drive controller. 
It is coded as follows: 



Bit 


7 


6 


5 


4 3 2 10 


RDC 


X 


X 


X MAC DRQ IPOL DSN 



3.7.15.1 Bit 7 Reset Drive Controller 

When this bit is asserted, then the drive controller 
subsection of the WD42C22C resets. It is held 
reset as lo ng as t he bit is asserted. This bit is 
reset when RESET is asserted. 



3.7.15.4 Bit 1 Input Polarity 

This b it is u sed to c ontrol t he polarity of the 
INDEX, SCT, WF, and DRDY inputs. If IPOL= 0, 
the default, then the inputs are active low. 
If IPOL = 1, then the inputs are active high. In 
soft sector MFM and RLL modes, DRUN is al- 
ways active high regardless of the state of IPOL. 



3.7.15.5 Bit Disable Sector Number 

When this bit is set, then the drive controller does 
not compare the sector number coming from the 
drive with the desired sector number when reads 
or writes are performed. The drive con- 
troller instead writes the sector number coming 
from the drive into the sector number register in 
the drive controller task file. At the end of each 
sector, just prior to issuing DRQI or DCI, the drive 
controller always writes the sector number to the 
altern ate sect or number register. This bit resets 
when RESET is asserted. 
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3.7.16 Alternate Sector Number 
(AD7 Thru ADO = 3C, Read) 

When the disk controller interrupts the 
microcontroller, this register holds the sector 
number of the sector just read or written. It is 
always updated just prior to the disk BDRQ inter- 
rupt (DRQI) or the disk controller interrupt (DCI). It 
is initialized to FF16 at the start of every com- 
mand. It is written regardless of the state of the 
DSN bit described above. 



Bit 


7 6 


5 


4 


3 


2 1 





NUMBER OF LAST SECTOR READ OR 
WRITTEN 



3.8 AT Interface Ports 



3.8.1 .3 Bit Auto-DRQ Enable 

When ADRQ = 1 in AT mode, then the 
WD42C22C automatically sets up the first data 
transfer from the host for write, write long, and 
format commands. When ADRQ = 0, the local 
microcontroller must set up all data transfers 
to/from the host for all commands. 



3.8.2 Drive Zero Status 

(AD7 Thru ADO = 3D, Read/Write) 

In PC/AT mode, bits 6, 5, 4, 2, and of the host 
status register are controlled by the local 
microcontroller. Bits 6, 5, 4, 2, and of the host 
status register are set to the values of bits 6, 5, 4, 
2, and 0, respectively, of this register if bit 4 of the 
AT task file copy SDH register (port 46 for 
microcontroller, port 6 for host) is 0. The other bits 
of the host status are not affected by this register. 



3.8.1 AT Control Register 

(AD7 Thru ADO = 2A, Read/Write) 

This register controls the new auto-DRQ option 
for write, write long, and format commands. 



Bit 


7 


6 


5 


4 


3 


2 1 




















0ADQ7 


ADRQ 



3.8.1 .1 Bits 7 Through 2 Reserved 

Set to 0. 



3.8.1 .2 Bit 1 Auto-DRQ 7 Byte ECC 

When ADRQ = 1 and ADQ = 1, then 7 ECC bytes 
are transferred to/from the host on a read long or 
write long command. When ADRQ = 1 and ADQ7 
= 0, then 4 ECC bytes are transferred to/from the 
host on a read long or write long command. When 
ADRQ = 0, then the ECC7 bit in the fixed disk 
register (3Fi6) controls the number of ECC bytes 
transferred on read long and write long com- 
mands. 



3.8.3 Drive One Status 

(AD7 Thru ADO = 3E, Read/Write) 

In AT mode, bits 6, 5, 4, 2, and bit of the host 
status register are controlled by the local 
microcontroller. Bits 6, 5, 4, 2, and of the host 
status register is set to the values of bits 6, 5, 4, 2, 
and 0, respectively, of this register if bit 4 of the AT 
task file copy SDH register (port 46 for 
microcontroller, port 6 for host) is 1 . The other bits 
of the host status are not affected by this register. 



3.8.4 Fixed Disk Register 

(AD7 Thru ADO = 3F, Read) 

This register contains the fixed disk register data 
written by the host. 




Bit 


7 


6 


5 


4 3 2 1 














HS3ENRSTIEN 






3§S 
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3.8.5 Digital input Register 

(AD7 Thru ADO = 3F, Write) 

Bit 5 of this register is written by the local 
microcontroller and read by the host if the fixed 
disk register bit 3 is zero. This bit is inverted when 
this register is read by the host. If HS3EN is one, 
then bit 5 of this register comes from SDH register 
bit 3. 



Bit 


7 6 5 4 


3 


2 1 


ECCMECC7/RWC X 
DDRQ 


X 


X DS1 DSO 



3.8.5.1 Bit 7 ECC Mode 

In PC/AT mode, ECCMOD = 1 indicates that the 
data transferred to the host includes ECC. The 
ECC is transferred in bytes ra ther than in words. 
This bit is reset when RESET is asserted. This bit 
should not be set in XT or slave host modes. 



3.8.5.5 Bit Drive Select 

This bit controls the state of th e DSO output pin. 
When DSO = 0, then the DS0_output is tri-stated 
and when DSO = 1 the th e DSO output is low. This 
bit is reset when RESET is asserted. 



3.8.6 AT Task File Copy 

(AD7 Thru ADO = 40 Thru 47, 
Read/Write) 

These registers are a copy of the disk controller 
task file. They are loaded by the host prior to the 
start of a command. The local microcontroller 
must read the command and interpret it and then 
copy the appropriate parameters from this task 
file copy to the actual drive controller task file 
(20i6-27i6). At the end of the command, the local 
microcontroller must update this task file copy 
before asserting INTRQ and resetting ABSY The 
local microcontroller can only access these 
registers when ABSY=1 . 



3.8.5.2 Bit 6 ECC 7 Bytes/ Disable BDRQ 

When ECCM = 1, then this bit determines the 
number of ECC bytes transferred to the host. If 
ECC7 = 1, then 7 bytes are transferred. Other- 
wise, 4 bytes are transferred. If ECCM = 0, then 
this bit controls whether or not the drive con- 
troller issues BDRQ interrupts. If DDRQ = 0, 
then the drive controller issues BDRQ inter- 
rupts. If DDRQ = 1, then the drive controller does 
not issue BDRQ interrupts. It should be noted that 
when BDRQ occurs, the buffer manager loads the 
disk pointer from its pipeline register and when no 
BDRQ occurs then the disk pointer keeps in- 
crementing from one sector to the next. This bit 
resets when RESET is asserted. 



3.8.5.3 Bit 5 Reduce Write Current 

This bit is set by the micro controller and indi- 
cates the state of the RWC signal going to the 
drive. 



3.8.5.4 Bit 1 Drive Select 1 

This bit controls the state of the D S1 output pin. 
When DS1 = 0, then the DS1 output is tri- 
stated and when DS1 = 1 the DS1 output is 
low. This bit is reset when RESET is asserted. 
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4.0 BUFFER MANAGER 
ORGANIZATION 

The buffer manager can control multiple sector 
buffers totalling up to 32 Kbytes. The buffer inter- 
face requires static RAMs. The sector buffers can 
be any size up to 2055 bytes, including ECC, and 
can be located at any byte boundary. The buffer 
manager has two address counters, one for the 
host interface and one for the disk data buffer. 
Both counters can access the SRAM simul- 
taneously. The buffer manager handles the ar- 
bitration between the host interface and the drive 
controller. There is a FIFO in the host data inter- 
face that allows a sustained bandwidth of 4 
Mwords/sec (8 Mbytes/sec) for 16-bit wide trans- 
fers and 8 Mbytes/sec for 8-bit wide transfers. 
The buffer manager can sustain a RAM 
bandwidth of 10 Mbytes/sec. 

When the local microcontroller wants to access 
the buffer RAM, it has to use the disk buffer 
manager logic. It first loads the desired starting 
address into the disk buffer pointer. The proper 
buffer manager control bits are then set to enable 
the local microcontroller access to the buffer. 
When the local microcontroller accesses the spe- 
cial RAM access port (register 36i6), the data is 
read/written through the disk controller's FIFO 
port to the buffer. The RAM can only be accessed 
sequentially from the starting address and only in 
one direction as set by the DRWB control bit in 
the buffer control register. 

Both address counters are pipelined. There are 
registers that can be loaded with the starting ad- 
dress of the next sector buffer while the current 
buffer is transferring. This allows noncontiguous 
buffers to be chained without any loss of RAM 
bandwidth between sectors. 



4.1 ACCESSING BUFFER RAM FROM THE 
MICRO-CONTROLLER 

The microcontroller can read and write the buffer 
RAM. To read the buffer RAM the procedure is: 

1 . Set DRWB = 1 (bit 2) in the buffer manager 
control Register (37i6). 

2. Set MAC = 1 (bit 3) in the disk controller con- 
trol register (3Bi 6). 

3. Load the starting address of the data being 
accessed into the disk buffer pointer 
registers (34&35i6). 

4. Set ADBP = 1 (bit 0) in the buffer manager 
control register (37i 6). 

The buffer manager begins reading data out of 
the RAM starting at the address specified in the 
disk pointer register and placing it into the FIFO. 
As the microcontroller reads from the RAM ac- 
cess port (36i6), sequential bytes from the buffer 
are transferred from the FIFO to the 
microcontroller. 

The procedure to write to the buffer RAM is: 

1 . Set DRWB = (bit 2) in the buffer manager 
control register (37i 6). 

2. Set MAC = 1 (bit 3) in the disk controller con- 
trol register (3Bi 6). 



3. 



4. 



Load the starting address of the data being 
accessed into the disk buffer pointer 
registers (34&3516). 




Set ADBP = 1 (bit 0) in the buffer manager 

control register (37i 6). 
As the microcontroller writes data to the RAM ac- 
cess port (36i6), the buffer manager transfers the 
bytes to sequential locations in the buffer RAM 
starting at the address specified in the disk pointer 
register. 

NOTE 

DRWB should not be changed while MAC = 1 . 
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4.2 STARTING HOST TRANSFERS 
TO/FROM BUFFER RAM 

Host transfers can be performed in several 
modes. The modes available and the setup re- 
quired to establish each mode are as follows: 



HDMA BDEN BCNT 


H16/8- 


1 X 
8-bit wide single byte DMA 





1 X 
1 6-bit wide single word DMA 


1 


1 1 
8-bit wide, 8-byte burst DMA 





1 1 
16-bit wide, 16-byte burst DMA 


1 


1 1 1 
8-bit wide, continuous burst DMA 





1 1 1 
16-bit wide, continuous burst DMA 


1 


X X 

8-bit wide PIO 





X X 

16-bit wide PIO 


1 



Bits HDMA (bit 7), BCNT(bit 5), and H16/8 (bit 1) 
are in the auxilliary buffer manager control 
register (2Fi6) and bit BDEN (bit 1) is in the buffer 
manager control register (37i6). All of these 
modes are available in both the XT and AT host 
configurations. All of the DMA modes are avail- 
able in the slave host configuration. 

To perform a Host read data transfer the following 
sequence should be followed. 

1 . Set up the appropriate transfer mode as 
described above. 

2. Set HRWB = 1 (bit 3) in the buffer control 
register (37i 6). 

3. Load the starting address of the desired sec- 
tor into the host pointer registers (30i6 & 

31 16). Load the number of bytes into the host 
transfer count registers (32i6 & 33i6). 

4. Set AHBP = 1 (bit 4) in the buffer manager 
control register (37i6). Hardware automat- 
ically sets DRQ (bit 3) and resets ABSY (bit 
7) in the host status register if AT mode and 
sets REQ (bit 0) in the hardware status 



6. 



register if XT mode. If DMA transfers are 
enabled, then the hardware automatically 
starts the DMA handshake when AHBP is 
set by the micro-controller. 

Wait for HPRI = 1 (bit 2) in the interface 
status register (38i6). MCINT is asserted. 

Set RHRI = 1 (bit 2) in the interface control 
register (38i6) to reset the interrupt. If chain- 
ing and still more sectors then go to 3. 



7. Wait for HPRI = 1 (bit 2) in the interface 
status register (38i6). MCINT is be asserted. 

8. Set RHRI = 1 (bit 2) in the interface control 
register (38i6) to reset the interrupt. If still 
more sectors, then go to 3. 

9. Set RBSY = 1 (bit 3) in the interface control 
register when the entire command sequence 
is complete. This resets the ABSY and 
XBSY host status bits. They stay reset until 
the next command is issued by the host. 

To perform a host write data transfer, the following 
sequence should be followed. 

1 . Set up the appropriate transfer mode as 
described above. 

2. Set HRWB = (bit 3) in the buffer control 
register (37i 6). 

3. Load the starting address of the desired sec- 
tor into the host pointer registers (30i6 & 

31 16). Load the number of bytes into the host 
transfer count registers (32i6 & 33i6) 

4. Set AHBP = 1 (bit 4) in the buffer manager 
control register (37i6). Hardware automat- 
ically sets DRQ (bit 3) and resets ABSY (bit 
7) in the host status register if AT mode and 
set REQ (bit 0) in the hardware status 
register if XT mode. If DMA transfers are 
enabled, then the hardware automatically 
starts the DMA handshake when AHBP is 
set by the micro-controller. 

5. Wait for HPRI = 1 (bit 2) in the interface 
status register (38i6). MCINT is asserted. 

6. Set RHRI = 1 (bit 2) in the interface control 

register (38i6) to reset the interrupt. If chain- 
ing and still more sectors then go to 3. 
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7. Wait for second HPRI = 1 ( bit 2) in t he inter- 

face status register (38i6). MCINT is as- 
serted. 

8. Set RHRI = 1 (bit 2) in the interface control 

register (38i6) to reset the interrupt. If still 
more sectors then go to 3. 

9. Set RBSY = 1 (bit 3) in the interface control 

register when the entire command sequence 
is complete. This resets the ABSY and XBSY 
host status bits. They stay reset until the 
next command is issued by the host. 



4.3 CONTROLLER COMMANDS 

The WD42C22C Winchester command set con- 
tains twelve commands. Four commands (read 
sector, write sector, format, and set parameter) 
are directly executed through the command 
register. The remaining commands are not directly 
available to the host. These commands may be 
executed by the local microcontroller transparent- 
ly to the host. Table 12 lists the commands and 
command codes. 



COMMAND 


7 


6 


5 


4 


3 


2 1 


Read Sector 








1 








M L T 


Read Next Data 





1 


1 








L 1 


Write Sector 








1 


1 


X 


M L T 


Write ID 


1 





1 


1 


F 


OAT 


Scan ID 





1 











T 


Format Track 





1 





1 





W 1 


Format Single Sector 


1 


1 





1 





W 1 


Compute Correction 














1 


POO 


Set Parameter 


z 








R 





E H S 


Load Parameter Block 


1 











1 


D K U 


Sleep 


1 








1 


1 





Dump 


1 





1 





I 


B L 1 


Mnemonic definitions for Table 1 2: 









TABLE 12. COMMAND AND COMMAND CODES 



M=0 Single sector read or write. Sector count 

is ignored. 
M=1 Multiple sector read or write. Used for 

1 :1 interleave. 

L=0 Normal mode, selected ECC or CRC 
functions performed. 



L=1 Sector extended by 4 or 7 bytes (de- 
pends on set parameter command. 
No ECC generated or checked. 

* T=0 Enable retries. 
T=1 Disable retries. 

■ X=0 Write sector specified in sector number 

register. 
X=1 Write sector specified in first byte of 
the sector buffer. 

- F=0 Write new ID immediately after current 

ID. 
F=1 Write new ID offset from current ID. 

• A=0 Do not pulse AME when writing new 

ID. 
A=1 Pulse AME when writing new ID. 

W=0 Write gate stays asserted for entire 

track or sector. 
W=1 Write gate deasserted over all gaps 

during format. 

P=0 Transfer syndrome bytes to buffer and 

calculate error pattern bytes and 

transfer them to the buffer. 
P=1 Transfer syndrome bytes to the buffer 

but do not calculate error pattern 

bytes. 

Z=0 MFMorRLLmode. 
Z=1 NRZ mode. Mode used for ESDI drive 
interface. 

R=0 Disable relocation ID searches. 
R=1 Enable relocation ID searches. 

E=0 Sector extension for read long/write 

long 4 bytes. ECC generator/checker 

is 4 bytes. 
E=1 Sector extension for read long/write 

long 7 bytes. ECC generator/checker 

is 7 bytes. 

H=0 SDH register programmed for 3 head 

select bits. 
H=1 SDH register programmed for 4 head 

select bits. 

S=0 Error correction span 5 bits with 4 

byte ECC or 1 1 bits with 7 byte ECC. 

S=1 Error correction span 1 1 bits with 4 
byte ECC or 22 bits with 7 byte ECC. 

D=0 Select soft sector drive interface. De- 
fault after master reset. 

D=1 Select hard sector drive interface. In 
this mode, DRUN becomes a sector 
pulse input. 




a 
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MODE 


MODE 
CONTROL 


OPTIONS 




Z 


D 


K 




M 


T 


L 


X 


A 


F 


R 


s 


E 


H 


p 


u 


w 


1 


B 


RLL soft sector 


? 








X 


X 


X 


X 


X 


X 


X 


X 


* 


X 


X 


X 








RLL hard sector 


? 


1 





X 


X 


X 


X 


X 


X 


X 


X 


* 


X 


X 


X 


X 


X 


X 


MFM soft sector 








1 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 








MFM hard sector 





1 


1 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


NRZ soft sector 


1 





1 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 








NRZ hard sector 


1 


1 


1 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


? Don't care, could be or 1 . 
x These options are supported. 
* These options have no effect. 



TABLE 13. OPTION SUMMARY TABLE 



K=0 



K=1 
U=0 



U=1 



l=0 



i=1 



B=0 
B=1 



RLL data interface. Selection of this 
option disables the NRZ option. De- 
faults to this setting after master re- 
set. 
Data interface is either MFM or NRZ. 

Use the standard sector sizes defined 
under the SDH register description. 
Select user defined sector size. The 
desired sector size is put into the 
cylinder registers prior to issuing a 
load parameter block command. The 
auxilliary set parameter command 
transfers the desired sector size from 
the cylinder registers to an internal 
sector size register. 

Dump two fields per sector. Dump 5 ID 
bytes and the number of data bytes 
set by the sector size. 
Dump only one field per sector. The 
sizeof the field is set by the sector 
size and type of field (ID versus data) 
is controlled by where RG is asserted. 

FE sync byte and zero preset CRC. 
A1 sync byte and ones preset CRC. 



Table 13 summarizes the data formats and op- 
tions supported by these formats. 



4.4 COMMAND DESCRIPTIONS 



4.4.1 Read Sector 

If M = 0, then the sector specified in sector num- 
ber register is read. If M = 1 , then multiple records 
are read. If the sector count register = 0, then 256 
sectors are read at the desired track. 

If T=0, then ID searches are retried for 10 index 
pulses. DAM not found errors are not retried. 
There are no retries for CRC/ECC errors. If T=1 , 
ID searches are retried for two index pulses. 

If L=0, then normal CRC or ECC read commands 
are performed. If L=1, then the CRC or ECC 
check bytes are not computed but instead the 
CRC or ECC check bytes are loaded into the buff- 
er immediately after the data field. The external 
sector buffer must be long enough to hold the 
additional 4 or 7 bytes. If ECC and retry modes 
have been selected and a data field error occurs 
there are no attempts to correct the data. 

A bad block mark in the ID field sets the error bit 
and the data field is not read. If the R option in the 
set parameter command is set then the controller 
searches immediately after the normal ID field for 
a special ID field containing mapping information 
and a special "Relocation ID" flag bit. The RIDF 
bit in the error register sets if this special ID field 
is found. If a bad block mark is found in an ID 
field then the command terminates immediately 
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even if more sectors remain to be read. The task 
file contents when a bad block bit is detected and 
the R option is used is as follows: 



REGISTER 


MEANING 


22 


Sector number of sector with 




bad block bit set 


23 


Sector umber where sector 




has been relocated 


24 


LSB of cylinder number 




where sector has been reloc- 




ated 


25 


MS bits of Cylinder where 




sector has been relocated 


26 


Head number of relocated 




sector 



If DSN = 1 (bit 0) in the drive interface control 
register (3Bi6) than the sector number is not com- 
pared when ID searches are performed. The 
WD42C22A reads the sector as long as the 
cylinder and head numbers match the desired 
values. This allows an interleaved track to be read 
into the buffer in one revolution. 

Command Flow: 



MICRO: 



1. 



2. 



4. 



5. 



WD42C22C: 7. 



8. 



Set DRWB = (bit 2) in the 
buffer manager control reg- 
ister (37i 6). 

Load the starting address of 
the first sector into the disk 
buffer pointer registers (34i6 
&35i 6 ). 

Set ECCM = (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC=1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 

Set ADBP = 1 (bit 0) in the 
buffer manager control reg- 
ister (37i 6). 

Set MAC = in the drive 
interface control register. 
Issue read command to 
WD42C22C. 

Write FF to alternate sector 
number register (3Ci6). 
Abort if drive not ready or 
write fault. 
(If DRQI is enabled) 
Activate BDRQ signal to 



MICRO 



WD42C22C: 9. 



10. 



MICRO: 



11. 



12. 



13. 



14. 



buffer manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating trans- 
fer of buffer pointer. 

Load starting address of next 
sector buffer into disk buffer 
pointer register. Set ADBP=1 
in buffer manager control reg- 
ister if more sectors remain- 
ing. Set RDQI (bit 1) in the 
interface control register 
(38ie). 

Search for head, cylinder, 
sector number, and sector 
size code. 

When the proper sector ID is 
found, read sector data and 
place in buffer. 
Write sector number to alter- 
nate sector number register. 
If M = 0, then go to 10. 
Decrement sector count, in- 
crement sector number. If 
M = 1 , and sector count = 
then go to 13 else go to step 
8. 

Set DCI (bit 3) in the inter- 
face sta tus register (38i6). 
MCINT asserted. 



Read disk controller status 
register (27i6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• ID not found set if ID field not found or 

if ID field matches, but CRC check fails, and 
after retry procedure. 

• Bad block set if attempt was made to read a 
sector with bad block mark. 

• Relocation ID found if R option enabled and 
relocation ID detected. 

• Data CRC/ECC set if data field CRC or ECC 
check fails. No attempt is made to correct 
ECC errors. 

• Data AM not found in set if data address mark 
not found. 
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4.4.2 Read Next Data 

The read next data command finds the next data 
field and places it in a buffer. If the WD42C22C 
detects that the drive number changed since the 
last read command, then an auto-scan ID is per- 
formed and step pulses are issued to update the 
present cylinder position. 

All searches for a data field are retried for two 
index pulses, but if a data ECC error is detected 
there are no retries. If after reading the correct ID 
field, the data address mark is not found a DAM 
error is set. 

The L flag controls the ECC check bytes. If L=0, 
then the data field is read and ECC is checked. If 
L=1, then the ECC check bytes are not computed. 
Instead, the ECC check bytes are loaded into the 
buffer immediately after the data field. The exter- 
nal sector buffer must be long enough to hold the 
additional 7 bytes. 

NOTE 
This command supports only soft sector MFM and 
RLL mode and is implemented for backward com- 
patibility with the WD5011 and WD5011 A. 

Command Flow : 



MICRO: 



1. 



3. 



4. 



5. 



6. 



WD42C22C: 7. 



Set DRWB = (bit 2) in the 
buffer manager control reg- 
ister (37i 6). 

Load the starting address of 
the first sector into the disk 
buffer pointer registers 
(34i6&35i 6 ). 
Set ADBP = 1 (bit 0) in the 
buffer manager control reg- 
ister (37i 6). 

Set ECCM = (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC=1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 

Set MAC=0 in the drive inter- 
face control register. 
Issue read next data com- 
mand to WD42C22C. 

Write FF to alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 
(If DRQI is enabled) 
Set DRQ status bit, activate 



BDRQ signal to buffer man- 
ager. Wait for BRDY signal 
indicating transfer of buffer 
pointer. 

• MICRO: Set RDQI (bit 1 ) in the inter- 

face control register (38i6). 

• WD42C22C: 9. Find next data field, read sec- 

tor data and place in buffer. 
If data mark error, try data 
field search again until 2 in- 
dex pulses occur. 
1 0. Copy sector number register 
to alternate sector number 
register (3Ci 6). Set DCI 
(bit 3) in the int erface s tatus 
register (38ie).MCINT is 
asserted. 

• MICRO: 1 1 . Read disk controller status 

register (27i 6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• Data CRC/ECC set if data field CRC or ECC 
check fails. No correction is attempted. 

• Data AM not found is set if data address mark 
not found after 2 index pulses of looking for 
any data field. 



4.4.3 Write Sector 

Write from buffer to disk when BRDY signal is 
activated by the buffer manager. Write total num- 
ber of sectors specified by sector count register if 
M = 1 . Sectors are written in numerical order. If M 
= 0, then sector count is ignored and only one 
sector is written. The data field PLO sync field is 
nominally 12 bytes long but is extended by the 
PLO register. 

If T = 0, then ID searches are retried for 10 index 
pulses. If T = 1, then ID searches are retried for 2 
index pulses only. 

If L = 0, then normal CRC or ECC write sector 
commands are performed. If L = 1 , then the CRC 
or ECC check bytes are not computed and written 
to the disk but instead, 4 or 7 additional bytes are 
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read from the buffer and written to the disk imme- 
diately after the data field. 

If X = 0, then the controller searches for the sector 
number in the sector number register and incre- 
ments the sector number register and the end of 
each sector if M = 1 . If X = 1 , then the controller 
searches for the sector specified in the first byte 
of the sector buffer. The controller reloads the 
sector number register from the first byte of each 
subsequent sector buffer if M = 1 . This allows a 
track formatted with interleave to be written in one 
revolution. 

A bad block mark in the ID field sets the error bit 
and the data field is not be written. If the R option 
in the set parameter command is set, then the 
controller searches immediately after the normal 
ID field for a special ID field containing mapping 
information and a special "Relocation ID" flag bit. 
The RIDF bit in the error register sets if this spe- 
cial ID field is found. If a bad block mark is found 
in an ID field then the command terminates imme- 
diately even if more sectors remain to be read. 
The task file contents when a bad block bit is 
detected and the R option is used is as follows: 



REGISTER 


MEANING 


22 


Sector number of sector with 
bad block bit set 


23 


Sector number where sector 
has been relocated 


24 


LSB of cylinder number where 
sector has been relocated 


25 


MS bits of cylinder where sec- 
tor has been relocated 


26 


Head number where sector 
has been relocated 



If DSN = 1 (bit 0) in the drive interface control 
register (3Bi6) then the sector number is not com- 
pared when ID searches are performed. The 
WD42C22C writes the sector as long as the 
cylinder and head numbers match the desired 
values. This allows an interleaved track to be writ- 
ten into the buffer in one revolution. This option is 
only useful when doing the initial write-after-for- 
mat to place 00 in the data fields. 

Command Flow: 

• MICRO: 1 . Set DRWB = 1 (bit 2) in the 

buffer manager control reg- 
ister (37i 6). 



6. 



WD42C22C: 7. 



MICRO: 



WD42C22C: 9. 



10. 



2. Load the starting address of 
the first sector into the disk 
buffer pointer registers 
(34i6&35i 6 ). 

3. Set ECCM = (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC = 1 (bit 3) in the drive 
register (3Bi6) to disable 
DRQI, if desired. 

4. Set ADBP=1 (bit 0) in the 
buffer manager control reg- 
ister (37i 6). 

5. Set MAC = in the drive 
interface control register. 
Issue write command to 
WD42C22C. 

Write FF to alternate sector 
number register (3Ci6). 
Abort if drive not ready or 
write fault. 
8. (If DRQ is enabled.) 
Activate BDRQ signal to 
buffer manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating 
transfer of buffer pointer. 

Load starting address of next 
sector buffer into disk buffer 
pointer register. Set ADBP=1 
in buffer manager control 
register if more sectors re- 
maining. Set RDQI (bit 1) in 
the interface control register 
(38ie). 

Search for head, cylinder, 

sector number and sector 

size code. 

When the proper sector ID 

is found, write buffer data to 

sector. 

11 . Write sector number to alter- 
nate sector number register 
(3C-I6). If M = 0thengoto 
13. 

1 2. Decrement sector count, in- 
crement sector number. If 
M = 1 and sector count = 
then go to 13 else go to step 
8. 

1 3. Set DCI (bit 3) in the inter- 
face sta tus register (38i6). 
MCINT asserted. 
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• MICRO: 14. Read disk controller status 
register (27i 6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• ID not found set if exact ID field not found or if 
ID field matches but CRC check fails, after 
retry procedure. 

• Bad Block set if write sector attempted on any 
sector with bad block mark. 

• Relocation ID found if R option enabled and 
relocation ID detected. 



The four bytes in the buffer (F 

follows: 

BYTEO 



0) should be as 



BYTE1 
BYTE 2 
BYTE 3 



1111 cyl 10 1 cyl9cyl8 
Low byte of cylinder number 
BB RF HS3 HS2 HS1 HSO 
Sector Number 



BB = 
RF = 



bad block flag 
Relocation ID flag 

upper three cylinder num- 



cyl 10 thru cyl 8 
ber bits 

HS3 thru HSO = head select bits 
The five bytes in the buffer (F = 1) should be as 
follows: 



4.4.4 Write ID 

Write from buffer to disk when BRDY signal is 
activated by the buffer manager. Write 4 bytes to 
create an ID field. The PLO sync field prior to this 
new ID field is nominally 12 bytes long but is ex- 
tended by the PLO register. A value of results in 
a 2048 byte PLO field and should not be used. 

If T = then ID searches are retried for 10 index 
pulses. If T = 1, then ID searches are retried for 2 
index pulses only. 

If F = 0, then the new ID is written immediately 
after the ID field of the desired sector. If F = 1, 
then the new ID field is written offset from the 
desired sector ID with the offset determined by 
the internal sector size register. A load parameter 
block command will have to be issued to set the 
offset value and another load parameter block will 
be needed to set the sector size back to the cor- 
rect value if the programmable sector size option 
is being used. An offset of up to 2048 is allowed. 
This option can be used to reformat a single sec- 
tor in soft sector mode. 

If A = 0, then the AME output is held low during 
the write ID command. If A =1, then the AME 
output is pulsed at the start of the PLO field 
before the new ID being written. This option, 
together with the F option, can be used to refor- 
mat a single sector in soft sector NRZ mode. 



BYTEO 
BYTE1 
BYTE 2 
BYTE 3 
BYTE 4 



Sector Number 



1111 cyl 10 1 cyl 9 cyl 8 
Low byte of cylinder number 
BB RF HS3 HS2 HS1 HSO 
Sector Number 



BB = bad block flag 

RF = Relocation ID flag 

cyl 10 thru cyl 8 = upper three cylinder num- 
ber bits 

HS3 thru HSO = head select bits 



RF should be set to 1 if the new ID being written 
is to be a special relocation ID for mapping a 
defective sector to a new position. 

Command Flow: 

• MICRO: 1 . Set DRWB = 1 (bit 2) in the 
buffer manager control regis- 
ter (37ie). 

2. Load the starting address of 
the ID buffer data into the 
disk buffer pointer registers 
(34i6&35i 6 ). 

3. Set ECCM = (bit 7) and 
DDRQ=1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC = 1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 
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4. Set ADBP = 1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

5. Set MAC = in the drive 
interface control register. 

6. Issue Write ID command to 
WD42C22C. 

• WD42C22C: 7. Write FF to alternate sector 

number register (3Ci6). 
Abort if drive not ready or 
write fault. 
8. (If DRQI is enabled) 

Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating trans- 
fer of buffer pointer. 

• MICRO: Set RDQI (bit 1 ) in the inter- 

face control register (38i6). 

• WD42C22C: 9. Search for head, cylinder, 

sector number and sector 
size code. 
10. When the proper sector ID is 
found, write buffer data to 
sector. 

• WD42C22C:1 1 . Write sector number to alter- 

nate sector number register. 
Set DCI (bit 3) in the interface 
status r egister (38i6). 
MCI NT asserted. 

• MICRO: 12. Read disk controller status 

register (27i6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write Fault and aborted command set if WF 
pin activated. 

• ID not Found set if exact ID field not found or if 
ID field matches but CRC check fails, after 
retry procedure. 

• Bad Block set if bad block bit detected in ID of 
desired sector. 



4.4.5 Scan ID 

When the next ID field of the present track is en- 
countered, cylinder number, sector size, head 
number and sector number are loaded into the 
respective registers. 



Command Flow: 



MICRO: 



1. 



WD42C22C 2. 



4. 



Issue Scan ID command to 
WD42C22C. 

Write FF to alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

Search for next ID field and 
read 4 ID bytes into respec- 
tive registers. Search for ID 
field for up to 1 index pulses 
if T=0, up to 2 index pulses if 
T=1. 

Set DCI (bit 3) in the interface 
status r egister (38i 6). 
MCINT asserted. 

• MICRO: 5. Read disk controller status 
register (27i 6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
active. 

• Bad Block set if bad block mark detected. 

• ID not found if no ID fields are found. 

• Relocation ID found if R option enabled and 
relocation ID detected. 



4.4.6 Format Track 

This command formats one track using 
parameters loaded in the task registers file and in 
buffer memory. 

Cylinder, head, and sector size numbers are 
taken from the task register file. Good block/bad 
block marks and sector numbers are taken from 
buffer memory. The total number of sectors for- 
matted is specified by the sector count register. 
The lengths of GAP 1 and GAP 3 are loaded into 
the sector number register. The length of the ID 
PLO sync field is loaded into the PLO length 
register if B = 1. The data PLO field length is 12 
bytes during format. 

The data placed in the gaps comes from an inter- 
nal register loaded during the load parameter 
block command. The data placed into the pads 
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comes from another internal register loaded 
during the load parameter block command. 

After the task register file has been loaded with 
the desired format parameters and the block 
marks and sector addresses have been loaded 
into the buffer then the command register is 
loaded with the format command. When the 
BRDY signal is activated by the buffer manager, 
the specified number of sectors are written. The 
block marks and sector numbers are read from 
the buffer as needed. The data field is written with 
FF. CRC is automatically computed and written if 
in CRC mode. If in ECC mode, ECC check bytes 
are automatically computed and written after the 
data field. The number of ECC check bytes is 
determined by the E bit in the set parameter com- 
mand. 

Write Gate is turned on and off within 4 bit times 
after index if NRZ or hard sector mode is selected 
or within 6 bit times otherwise. In RLL mode, 
Gap1/Gap3 data should be programmed to be 
33i6 with the load parameter command. The W 
option controls the state of WRITE GATE over the 
gaps. If W=1, WRITE GATE turns off over the 
gaps. 

The sum of the number of bytes in both the 
Gap1/Gap3 and ID PLO field must be greater 
than or equal to 25 bytes to achieve 1:1 inter- 
leave. 

The interleave table contains the bad block marks 
and sector numbers for the track. If there is a bad 
sector and it is desired for the controller to just 
skip over it, then the bad block mark for that sec- 
tor position should be set to 80i6 and the sector 
number for that sector should be set to FF16. If it 
is desired to map the bad sector then the bad 
block mark for that sector should be set to 80i6 
and the sector number for that sector should be 
set to the correct value for that position in the 
interleave table. The R and U options should be 
set in the set parameter and load parameter block 
commands. A write ID command then places the 
relocation information for that sector onto the 
drive. 

The interleave table format is: 

• BYTE 0: 1 st sector's block mark 

(00i6or80i6) 

• BYTE 1 : 1st sector's sector number 



BYTE 2: 
BYTE 3: 

BYTE2n: 
BYTE 2n+1 : 



2nd sector's block mark 

(00i6or80i6) 

2nd sector's sector number 



nth sector's block mark 

(00i6or80i6) 

nth sector's sector number 



Command Flow: 



MICRO: 



1. 



2. 



3. 



4. 



5. 



WD42C22C: 7. 



MICRO: 

WD42C22C: 9. 
10. 



Set DRWB = 1 (bit 2) in the 
buffer manager control regis- 
ter (37ie) 

Load the starting address of 
the interleave table into the 
disk buffer pointer registers 
(34i6&35i 6 ). 
Set ECCM = (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC = 1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 

Set ADBP = 1 (bit 0) in the 
buffer manager control reg- 
ister (37i 6). 

Set MAC = in the buffer 
control register. 
Issue format command to 
WD42C22C. 
Write FF to the alternate 
sector number register 
(3Ci6). Abort if drive not 
ready or write fault. 
(If DRQI is enabled) 
Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating trans- 
fer of buffer pointer. Wait for 
leading edge of index. 

Set RDQI (bit 1) in the inter- 
face control register (38i 6). 

Write gap. 

Write sector ID using para- 
meters in task register file 
and buffer memory. Data 
bytes are FF. 
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1 1 . Decrement sector count reg- 
ister. If sector count = 0, then 
go to step 1 2, else go to 
step 9. 

1 2. Write Gap until leading edge 
of index pulse. 

1 3. De-assert Write Gate. 

14. Set DCI (bit 3) in the inter- 
face sta tus register (38i6). 
MCINT asserted. 

• MICRO: 1 5. Read disk controller status 
register (27i6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

Note 

Gap length written on disk is 3 bytes longer than 
gap value specified in sector number register. 



4.4.7 Format Single Sector 

This command formats one sector using 
parameters loaded in the task register file and in 
buffer memory. This command only applicable to 
hard sector mode. 

WRITE GATE is turned on and off within 4 bit 
times after index or sector if NRZ mode is 
selected or within 6 bit times otherwise. The W 
option controls the state of WRITE GATE over the 
gaps. Setting W to 1 turns off WRITE GATE over 
the gaps. 

Cylinder, head, and sector size numbers are 
taken from the task register file. Good block/bad 
block marks and sector number are taken from 
buffer memory. The physical sector position to be 
formatted is specified by the sector count register. 
If sector count = 1 , then the first sector after index 
is formatted. For sector count = 2, the second 
sector after index is formatted, and so on. The 
lengths of GAP 1 and GAP 3 are loaded into the 
sector number register/The length of the ID PLO 
sync field is loaded into the PLO length register. 

The data placed in the gaps comes from an inter- 
nal register loaded during the load parameter 
block command. The data placed into the pads 



comes from another internal register loaded 
during the load parameter block command. 

After the task register file has been loaded with 
the desired format parameters and the block 
marks and sector number loaded into the buffer, 
then the command register is loaded with the for- 
mat single sector command. When the BRDY pin 
is activated by the buffer manager, the controller 
then looks for the start of the desired sector. The 
bad block mark and sector number are read from 
the buffer. The data field is written with FF. CRC is 
automatically computed and written if in CRC 
mode. If in ECC mode, ECC check bytes are 
automatically computed and written after the data 
field. The number of ECC check bytes is deter- 
mined by the E bit in the set parameter command. 

The data for the buffer is: 

• BYTE 0: bad block mark (00i 6 or 8O1 6) 

• BYTE 1 : sector number of formatted sector. 
Command Flow: 



MICRO: 



1. 



4. 



5. 



6. 



WD42C22C: 7. 



Set DRWB = 1 (bit 2) in the 
buffer manager control regis- 
ter (37ie). 

Load the starting address of 
the interleave table into the 
disk buffer pointer registers 
(34i6&35i 6 ). 

Set ECCM=0 (bit 7) and DDRQ 
=1 (bit 6) in the DIR write reg- 
ister (3Fi6) and MAC=1 (bit 
3) in the drive interface con- 
trol register (3Bi6) to dis- 
able DRQI, if desired. 
Set ADBP = 1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

Set MAC=0 in the drive inter- 
face control register. 
Issue format single sector 
command to WD42C22C. 

Write FF to the alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 
(If DRQI is enabled) 
Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for BRDY 
signal indicating transfer of 
buffer pointer. Wait for leading 
edge of index. 
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• MICRO: Set RDQI (bit 1 ) in the inter- 

face control register (38i6). 

• WD42C22C: 9. Decrement sector count. If 

sector count = go to 1 1 , 

else go to 10. 
1 0. Wait for SECTOR pulse, then 

go to 9. 
1.1. Assert WRITE GATE. Write 

gap. 

• WD42C22C:12. Write sector ID using para- 

meters in task register file and 
buffer memory. Data bytes 
are FF. 

13. Write gap until leading edge 
of SECTOR pulse. 

14. De-assert Write Gate. 

15. Set DCI (bit 3) in the inter- 
face sta tus register (38ir). 
MCINT asserted. 

• MICRO: 1 6. Read disk controller status 

register (27i6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 



4.4.8 Compute Correction 

This command is used to compute the pattern and 
location of a single burst error. It is used after a 
read sector command has detected a data field 
ECC error. The compute correction command 
first writes the four or seven syndrome bytes into 
the buffer. It then processes the syndrome bytes 
to compute the error pattern and error location. 
The error location and error pattern bytes are writ- 
ten into the buffer. Either four or seven error pat- 
tern bytes are written to the buffer depending on 
the ECC length selected. The error pattern bytes 
are automatically byte aligned. 

The P option is used to control whether or not the 
error pattern bytes are calculated. If P = 0, then 
the error pattern bytes are calculated and sent to 
the buffer. If P = 1 , then the error pattern bytes are 
not calculated. Only the syndrome byte is trans- 
ferred to the buffer. This option facilitates firmware 
algorithms that require a matching syndrome 
before a correction is made. In this case, the 
firmware calculates the error pattern, corrects the 



error, and saves the syndrome after initially 
detecting the error. Then, the firmware dumps and 
compares the syndrome on the second read of 
the same sector. An ECC error can now be cor- 
rected in one revolution of the disk compared to 
three revolutions required by earlier WD1010 and 
WD2010 based controllers. 

The error pattern and error location bytes are not 
valid if the error is found to be uncorrectable. An 
uncorrectable error is indicated by the appropriate 
bits in the status and error register. 

The buffer contents contains the following infor- 
mation: 

• SYNDROME BYTE (MSB) 

• SYNDROME BYTE 

• SYNDROME BYTE 

• SYNDROME BYTE (LSB if 4 byte ECC) 

• SYNDROME BYTE (if 7 byte ECC) 

• SYNDROME BYTE (if 7 byte ECC) 

• SYNDROME BYTE (LSB if 7 byte ECC) 

• BYTE OFFSET (MSB) 

• BYTE OFFSET (LSB) 

• ERROR PATTERN (MSB) 

• ERROR PATTERN 

• ERROR PATTERN 

• ERROR PATTERN (LSB if 4 byte ECC) 

• ERROR PATTERN 

• ERROR PATTERN 

• ERROR PATTERN (LSB if 7 byte ECC) 

If the byte offset is 0, then the first data byte of the 
sector should be exclusive OR'ed with the first 
error pattern byte (MSB). Each succeeding data 
byte exclusive OR'ed with the succeeding error 
pattern byte until the fourth data byte is exclusive 
OR'ed with the fourth error pattern byte (LSB). 
Exclusive OR the first two error pattern bytes for 5 
bit spans. Exclusive OR the first three error pat- 
tern bytes for 11 bit spans. Exclusive OR the first 
four error pattern bytes for the 22 bit span. 

Command Flow: 



MICRO: 



1. 



2. 



Set DRWB=0 (bit 2) in the 
buffer manager control regis- 
ter (37ie). 

Load the starting address of 
the error correction data buff- 
er into the disk buffer pointer 
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3. 



5. 



WD42C22C: 7. 



8. 



MICRO: 



WD42C22C: 9. 



10. 



MICRO: 



11. 



12. 



13. 



registers (34i 6 &35i 6). 
Set ECCM=0 (bit 7) and DDRQ 
=1 (bit 6) in the DIR write reg- 
ister (3Fi 6) and MAC=1 
(bit 3) in the drive interface 
control register (3Bi6) to 
disable DRQI, if desired. 
Set ADBP=1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

Set MAC=0 in the drive inter- 
face control register. 
Issue compute correction 
command to WD42C22C. 

Write FF to the alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 
(If DRQI is enabled) 
Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for BRDY 
signal indicating transfer of 
buffer pointer. 

Set RDQI (bit 1) in the inter- 
face control register (38i6). 

Transfer contents of the four 
(or seven) byte ECC register 
to buffer, most significant byte 
first. 

Clock the ECC register. Stop 
if correctable pattern found or 
if number of clocks exceeds 
sector size. If number of 
clocks exceeds sector size, 
set error bit of status register 
and ECC error of error regis- 
ter. 

Transfer byte count to buffer 
(2 bytes). Transfer 4 bytes of 
error pattern to buffer if 4 
byte ECC. Transfer 7 bytes 
of error pattern 7 byte ECC. 
Set DCI (bit 3) in the interface 
status r egister (38i6). 
MCINT asserted. 



Read disk controller status 
register (27i6) and error 
register (21 16). 

Error Flags: 

• CRC/ECC flag set if data field error length ex- 
ceeds correction span. 



NOTE 

Default 11 bit correction span after master reset if 
7-byte ECC or 5 bit correction span if 4-byte ECC. 



4.4.9 Set Parameter 

The E bit is used to select either 4 byte or 7 byte 
sector extension for read long and write long com- 
mands. It also selects either a 4 or 7 byte internal- 
ly generated ECC. A 7 byte sector extension and 
7 byte ECC are the default after a master reset 
(due to RLL default). If E is 0, then a 4 byte sector 
extension and 4 byte ECC are selected if MFM or 
NRZ mode. If E is 1, then a 7 byte sector exten- 
sion and 7 byte ECC are selected. 

The H bit selects either 3 or 4 head select bits in 
the SDH register. If H=0, then 3 head select bits 
are written or compared in the ID fields on the 
drive. If H=1 , then 4 head select bits are written or 
compared in the ID fields on the drive. The 
default after master reset is 3 head select bits. 

The S bit is used to select either a 5 bit or 11 bit 
correction span if 4 byte ECC and an 11 bit or 22 
bit correction span if 7 byte ECC. An 11 bit correc- 
tion span for 7 byte ECC is the default parameter 
following master reset. If S is 0, then a 5 bit cor- 
rection span is selected if 4 byte ECC, 11 bit 
correction span if 7 byte ECC. If S is 1, then an 
11 bit correction span is selected if 4 byte ECC, 
22 bit correction span if 7 byte ECC. 

The Z bit is used to select MFM, RLL, or NRZ 
mode. If K=0 in the load parameter block com- 
mand, then RLL coding is selected regardless of 
the state of Z. If Z is and K is 1 , then MFM 
coding is selected. If Z is 1 and K = 1, then NRZ 
coding is selected. 

The R option is used to enable relocation ID 
searches. If R=1 for read and write sector com- 
mands and a bad block mark is detected in the 
desired sector's ID, then the WD42C22C sear- 
ches for a special ID field containing relocation 
information immediately after the desired sector's 
ID. This special ID field is placed using the write 
ID command. When the R option is used, then the 
U option must be set to 1 in the load parameter 
block command. 




ft 
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Command Flow: 

• MICRO: 1 . Issue set parameter com- 

mand to WD42C22C. 



WD42C22A: 2. 



• MICRO: 

Error Flags: 

• None. 



4. 



5. 



Write FF to the alternate sec- 
tor number register (3Ci 6). 
Abort if drive not ready or 
write fault. 

Set or reset internal para- 
meter flip-flop. 

Set DCI (bit 3) in the interface 
status r egister (38i6). 
MCINT asserted. 

Read disk controller status 
register (27i6) and error 
register (21 16). 



4.4.10 Load Parameter Block 

The D bit is used to indicate the sectoring mode. 
If D = 0, the default after a master reset, then soft 
sector mode is selected. If D = 1 , then hard sector 
mode is selected. In hard sector mode, the PLO 
length register is transferred to the internal GAP 
length register during the load parameter block 
command. This GAP register is used to control 
the delay from INDEX/SECTOR to READ GATE 
on. 

The K bit selects the data interface mode. If K=0, 
the default after a reset, then RLL mode is 
selected. If K=1, then the interface is either MFM 
or NRZ as selected by the set parameter com- 
mand. 

The U bit selects the sector size options. If U=0, 
then the sector sizes are 128, 256, 512, and 1024 
depending on the contents of the SDH register. If 
U=1 , then the sector size is defined by the user. 
The cylinder registers are loaded with the desired 
sector size prior to issuing the load parameter 
block command. 

In addition, the load parameter block command is 
used to load several internal parameters for for- 
mat, read, and write commands. The task file is 
loaded with these parameters prior to the start of 
the command. The registers loaded and the cor- 
responding parameters are: 



REGISTER 


PARAMETER 


21 


Delay from INDEX/SECTOR to 
RG 


22 


Data written in GAPS 


23 


Data written in PADS 


24 


LS byte of sector size, LS byte 
of offset for write ID command 


25 


3 MS bits of sector size, 3 MS 




bits of offset for write ID com- 




mand 



Command Flow: 



MICRO: 



1. 
2. 



WD42C22C: 3. 



4. 



MICRO: 



Error Flags: 

• None. 



6. 



7. 



Load parameters into task file. 
Issue load parameter block 
command to WD42C22C. 

Write FF to the alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

Set or reset internal parameter 
flip-flop. 

Copy cylinder registers to in- 
ternal sector size register. 
Copy PLO register to internal 
GAP register. Copy sector 
count register to internal GAP 
data register. Copy sector 
number register to internal 
PAD data register. 
Set DCI (bit 3) in the interface 
status r egister (38i6). 
MCINT asserted. 

Read disk controller status 
register (27i6) and error 
register (21 16). 
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4.4.11 Sleep 

The sleep command places the WD42C22C in a 
low power standby mode. When the sleep com- 
mand is issued, the disk controller section clocks 
are disabled and only the buffer manager and 
host interface logic is enabled. The disk controller 
can be brought out of the sleep mode by setting 
RDC = 1 (bit 7) in the disk controller control 
register (3Bi6) or by resetting the entire 
WD42C22C. The microcontroller should NEVER 
attempt to read or write the drive controller task 
file (registers 21 16 through 27i6) while the drive 
controller is in the sleep mode. 

Command Flow: 

• MICRO: 1 . Issue sleep command to 

WD42C22C. 

• WD42C22C: 2. Write FF to the alternate sec- 

tor number register (3Ci6). 
3. Disable drive controller clocks. 



Wake up disk controller by 
setting RDC=1 or by resetting 
theWD42C22C. 



• MICRO: 

Error Flags: 

• None. 

4.4.12 Dump 

The dump command sends data off the media 
regardless of matching ID fields and regardless of 
the format. The command can dump an ID field, a 
data field, or both. Dump retrieves all the ID fields 
from index to index to determine the interleave. 
Dump can also read the ESDI standard defect list. 
The command dumps data starting at the first 
byte after the A1 sync byte for WD format or the 
first byte after the FE sync byte for ESDI format. 
This command can only do multisector dumps in 
hard sector mode. 

The command is assumed to be a multisector 
command. To read just one sector as in an ESDI 
defect list read, then the sector count must be set 
to one. There are three options. 

The I option controls the number of fields that are 
dumped for each sector. If I = 0, then two fields 
(ID and data) are dumped for each sector. If I = 1 , 
then only one field is dumped for each sector. The 
type of field is determined by the read gate delay 
and the sector size. The sector size should be 



programmed to 1 less than the number of bytes to 
be dumped for the sector. 

The B option controls the sync byte and CRC 
preset. If B = 0, then the sync byte is assumed to 
FE and the CRC is preset to all zeroes. If B = 1, 
then the sync byte is assumed to be A1 and the 
CRC is preset to all ones. 

The L option selects either CRC or no CRC 
checking. If L = 0, then CRC is checked. If L = 1, 
then either four or seven check bytes are trans- 
ferred to the buffer depending on the extension 
selected by the set parameter command. If L = 1 , 
then I should also be set to 1. B does not affect 
the L option. 

The PLO register controls the read gate delay for 
the first sector. READ GATE turns on x + 5 + CL 
bytes after the index pulse. Read gate for sub- 
sequent sectors is controlled as in normal read 
and write commands. 

Use the dump command to read an ESDI defect 
list as follows: 

1 . Set PLO register = read gate delay - 5. 

2. Set sector size = 255 for 256 byte sector. 

3. Issue A1 command. 

Use the dump command to dump the track inter- 
leave for WD format as follows: 

1 . Set PLO register = read gate delay - 5. 

2. Set sector size = 4. 

3. Set sector count = number of sectors per 
track. 

4. Issue AD command. 

Use the dump command to dump all the data 
fields on a track for WD format as follows: 

1 . Set PLO register = read gate delay to start of 
data PLO - 5. 

2. Set sector size = actual number of bytes per 
sector. 

3. Set sector count = number of sectors per 
track. 

4. Issue AF command or AB command. 

In this case, the F8 second data sync byte is 
transferred to the buffer. The buffer requires one 
extra byte per sector. 
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One BRDQ interrupt occurs at the very beginning 
of the command. Therefore, the buffer must be 
contiguous and large enough to handle all the 
dumped sectors. 

Command Flow: 

• MICRO: 1 . Set DRWB = (bit 2) in the 

buffer manager control regis- 
ter (37ie). 

2. Load the starting address of 
the buffer into the disk buffer 
pointer register (34i6 & 35i6). 

3. Set ECCM = (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC = 1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, 

if desired. 

4. SetADBP=1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

5. Set MAC = in the drive inter- 
face control register. 

6. Issue dump command to 
WD42C22C. 

•WD42C22C 7. Write FF to alternate sector 
number register (3Ci6). 
Abort if drive not ready or 
write fault. 
8. (If DRQI is enabled) 

Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for BRDY 
indicating transfer of buffer 
pointer. 

• MICRO: Set RDQI (bit 1 ) in the inter- 

face control register (38i6). 

• WD42C22C: 9. Wait for index. 

1 0. If 1=1 , then go to 1 2 else go 
toll. 

1 1 . Search for sync byte. When 
found, dump 5 data bytes 
into buffer. 

1 2. Search for sync byte. When 



found, dump programmed 
number of bytes into the buff- 
er. 

13. Decrement sector count. If 
sector count = 0, then go to 
14 else go to step 10. 

1 4. Set DCI (bit 3) in the interface 
status r egister (38i6). 
MCINT asserted. 

•MICRO: 15. Read disk controller status 
register (27i6) and errror 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• ID not found set if I = and index detected 
while searching for an ID field or if CRC of ID 
field doesn't zero. 

• Data AM not found is set and index is 
detected while searching for a data field. If l=0 
or when searching for either an ID or data field 
when 1 = 1. 

• Data CRC if the data field CRC doesn't zero 
when I = or if either an ID or data field CRC 
doesn't zero when 1 = 1. 
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5.0 ELECTRICAL AND TIMING 
SPECIFICATIONS 

5.1 MAXIMUM RATINGS 

Vccwith respect to Vss (ground) +5 V±5% 

Max voltage on any pin with respect to Vss -0.5V to 5.5 

Operating temperature (T A ) 0°C (32°F)to70°C (158°F) 

Storage temperature -55°C (-67°F) to 125°C (257°F) 

NOTE 

Maximum limits where permanent device damage 
occurs. Continuous operation at these limits is not 
intended and should be limited to those conditions 
specified in the DC operating characteristics. 

5.2 DC OPERATING CHARACTERISTICS 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


IlL 


Input Leakage 




±10 


HA 


Vin = 0.4 to Vcc 


loz 


Tri-state and open drain 
output leakage 




±10 


^A 


Vout = 0.4 TO Vcc 


V| H 


Input High Voltage 


2.0 




V 




V|L 


Input Low Voltage 




0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Iout=-800|iA 


Vol 


Output Low Voltage 




0.4 


V 


louT=2.0mA 


Ice 


Supply Current 




100 


mA 


All outputs open. 


Ices Supply Current (Standby 25 
Mode) 
For pins 75 thru 82, 40 thru 42, 44 thru 48, 74, 8 


mA 


All inputs at Vdd or Vss, disk con- 
troller sleep mode, 15 MHz crystal. 




TABLE 14. DC OPERATING CHARACTERISTICS 



(HD0 thru HD15, INTRQ, DREQ): 






SYMBOL CHARACTERISTIC 


MIN MAX UNITS 


CONDITIONS 


Voh Output High Voltage 
Vol Output Low Voltage 


2.4 V 
0.4 V 


louT=-5mA 
louT=12mA 



For pin 8 (IOC 


)S16, AT PIO mode only): 








SYMBOL 


CHARACTERISTIC 


MIN MAX 


UNITS 


CONDITIONS 


Vol 


Output Low Voltage 


0.4 


V 


lo=20.0mA 
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For pins 10, 11, and 12 (WD, EARLY, LATE ): 



SYMBOL 


CHARACTERISTIC 


MIN MAX UNITS 


CONDITIONS 


VOH 

Vol 


Output High Voltage 
Output Low Voltage 


2.4 

0.4 V 


Io=-800jliA 
lo=6.0mA 



For pin 22 (RESET) 






SYMBOL CHARACTERISTIC 


MIN MAX UNITS 


CONDITIONS 


Vol Output Low Voltage 


0.4 V 


lo=6.0 mA and VDD at spec. 
IO=2.0 mA and VDD at VRST2 
max 
VRST3 max. 



For pins 36, 37 (DSO, DS1) 



SYMBOL 


CHARACTERISTIC 


MIN MAX 


UNITS 


CONDITIONS 


Vol 


Output Low Voltage 


0.4 


V 


lo=48.0 mA 



For pins 59-73 (BA0-B1 4) 








SYMBOL CHARACTERISTIC 


MIN MAX 


UNITS 


CONDITIONS 


Ipd Pulldown Current in 
read config. mode 


40 160 


HA 


V UT=2.4V 



For pins 5, 6, 9 (HRE, HWE, and DACK in slave 
host mode) and pins 40-42, 44-48 (HD8 through 
HD15 in 8-bit host mode): 



SYMBOL CHARACTERISTIC MIN MAX 


UNITS 


CONDITIONS 


Ipu Pullup Current 100 2000 


^ 


Vout=0.4 V, Vdd=5.25 V 


For pin 38 (XTALIN when driven by external osc): 


SYMBOL CHARACTERISTIC MIN MAX 


UNITS 


CONDITIONS 


Vih Input High Voltage 3.5 

VIL Input Low Voltage 1.0 


V 
V 
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V_ 5.0 




/ 








V 


\ 


- V 


HST2 

Vrsti » 








RST3 
^ VrST4 








\ 


RESET 

on / 








« *■ no 1 L 

(Refer to MISC. timings.) 









FIGURE 6. POWER QUALIFIED RESET VOLTAGE THRESHOLD 



For p i ns 1-7 , 9, 15, 16, 20, 2 1, 23 , 25-35, 40-42, 44-48 , 51-5 8,59-73,74, 75-82 (HA0-HA2, HA9, HRE, 
HWE, HCS, DACK, INDEX, SCT, WF, DRDY, RESET, ALE, MRE, MWE, AD0-AD7, HD8-HD15, BD0- 
BD7, BA0-BA15, INTRQ, HD0-HD7) 




SYMBOL 



CHARACTERISTIC MIN MAX UNITS 



CONDITIONS 



VIH/VIL 



Input Voltage 
Hysteresis 



400 



mV 



For pin 84 (V[ 


)D) 










SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


Vrsti 

VRST2 
VRST3 
VRST4 


Power Qualified Reset 
Voltage Threshold 


0.0 
2.5 
2.5 
0.0 


2.0 
4.6 
4.6 
2.0 


V 
V 
V 
V 


See Figure 7. 
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5.3 AC TIMING CHARACTERISTICS 

NOTE 

Load capacitance=50 pF each for all other out- 
puts. Timings must be derated for larger load 
capacitances. 



For pins 14, 16, 17, 19 ( WC, DRUN, RD, RC ): 




SYMBOL CHARACTERISTIC MIN MAX UNITS 


CONDITIONS 


tRs Rise Time 10 nsec 


10% to 90% 



HA9, HA2, 
HA1,HA0_ 



HCS 



HWE 



HD7-HD0 



IOCS16 
(AT only) 



tASW 



twE 



« t AICSI ► 



FIGURE 7. AT/XT HOST PROGRAMMED I/O WRITE TIMING 



NOTE 



A wri te occurs during the overlap of HCS and 
HWE. 
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5.3.1 AT/XT 
Timing 


Host Programmed 


I/O Write 






SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


tASW 


Address Setup to 
HWE Low 


30 




ns 




tcsw 


HCS Setup to HWE 
Low 


10 




ns 




tDS 


Data Setup to HWE 
High 


30 




ns 


Port only. 


tWE 


HWE Pulse Width 


75 




ns 


Port only. 


tDS 


Data Setup to HWE 
High 


50 




ns 


All other ports. 


tWE 


HWE Pulse Width 


100 




ns 


All other ports 


tDH 


Data Hold from 
HWE High 


15 




ns 




tAHW 


ADDR Hold from HWE 
High 


20 




ns 




tCHW 


HCS Hold from HWE 
High 


10 




ns 




tWER 


HCS and HWE Inact- 
ive 


20 




ns 




twCY 


Write Cycle Time 


125 
2*X 




ns 


Port0,XTAL>16MHz 

Port 0, XTAL<16MHz (X=txTAi_) 


twCY 


Write Cycle Time 


150 




ns 


All other ports 


tcicsv 


IOCS1 6 valid from 
HCS 




30 


ns 




tAICSV 


IOCS1 6 valid from 
address 




40 


ns 




tcicsi 


IOCS1 6 inactive from 
HCS 




35 


ns 


Test circuit 1 . 


tAICSI 


IOCS1 6 inactive from 
address 




45 


ns 


Test circuit 1 . 



TABLE 15. AT/XT HOST PROGRAMMED I/O WRITE TIMING 



IOCS16 



300 OHMS 



4.5 V 




50 pF 



FIGURE 8. TEST CIRCUIT 1 



23 
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HA9, HA2, 
HA1,HA0 



HCS 
(ACTIVE) 



HCS 
(INACTIVE). 



HRE 



HD7-HD0 



I0CS16 
(AT only) 



tASE 



tcSE 



tcSE 



tRE- 



* — t, 



-tAHE 



t AICSI 



r 



tHDTS 



1 CICSI 



FIGURE 9. AT/XT HOST PROGRAMMED I/O READ TIMING 
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5.3.2 AT/XT 
Timing 


Host Programmed 


I/O Read 






SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


tASE 


Address Setup to HRE 
Low 


30 




ns 




tcSE 


HCS Setup to HRE 
Low 


10 




ns 




tDAC 


Data Valid from HRE 
Low 




60 
70 
100 


ns 


Port 0, 8-bit. 
PortO, 16-bit. 
All other ports. 


tRE 


HRE Pulse Width 


75 
100 




ns 


Port 

All other ports 


tDOH 


Data Hold from HRE 
High 


5 




ns 




tHDTS 


Data Tri-state from 
HRE 




50 


ns 




tHLD 


Address, HCS Hold 
from HRE High 


10 




ns 




tRDR 


HCS and HRE Inact- 
ive 


20 




ns 




tRDCY 


Read Cycle Time 


125 
2*X 




ns 


PortO,XTAL>16MHz 

Port 0, XTAL<16 MHz (X=txTAi_) 


tRDCY 


Read Cycle Time 


150 




ns 


All other ports. 


tcicsv 

tAICSV 


IOCS1 6 Valid from 
HCS 




30 
40 


ns 
ns 




IOCS1 6 Valid from 
Address 


tcicsi 


IOCS1 6 Inactive from 
HCS 




35 


ns 


Test circuit 1 


tAICSI 


IOCS1 6 Inactive from 
Address 




45 


ns 


Test circuit 1 




TABLE 16. AT/XT HOST PROGRAMMED I/O READ TIMING 
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5.3.3 AT/XT Host DMA Write Timing 





« tQLQL ► 




«— ^LQL — ► 




\ 


DREQ / 


\ 




\ 


N ^ 




\ 






« — twHDH — ► 

/ 


«— ^DWI — *■ 
















DACK N 


1 fc 




* twHQL 


4 lWR * 


V 


/ 




\ / 














* WHQL * 


HWE \ 
HD7- 


/ 


\ 


\ / 








«— tDVWH — * 


4 I d 

< t\/VHDI — > 


wi r 






HDO 


\ 


l< 


X 

























FIGURE 10. AT/XT HOST DMA WRITE TIMING 
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SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


tDLQL 






100 


ns 


BDEN=0 


DACK Low to DRQ 
Low 


tWHQL 


HWE High to DRQ 
Low 




4*X 

+100 


ns 


BDEN=1 . First transfer count throt- 
tle. (X=t X TAL) 


tDK 
tDLWL 


DMA Cycle . 


100 
2*X 






ns 
ns 


XTAL=20MHz 
AnyXTAL(X=txTAL) 


DACK Low to HWE 
Low 


tWR 


HWE Pulse Width 


80 




ns 




tDVWH 
tWHDH 


Data Valid to HWE 
High 


30 





ns 
ns 




HWE High to DACK 
High 


tWHDI 


HWE High to Data In- 
valid 


15 




ns 




tDWI 


DACK and HWE In 
active 


20 




ns 





TABLE 17. AT/XT DMA WRITE TIMING 



12/4/90 



26-63 



WD42C22C 



ELECTRICAL AND TIMING SPECIFICATIONS 



5.3.4 AT/XT Host DMA Read Timing 




FIGURE 11. AT/XT HOST DMA READ TIMING 
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SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


tDLQL 






100 


ns 


BDEN=0 


DACK Low to DRQ 
Low 


tRHQL 


HRE High to DRQ 
Low 




4*X 

+100 


ns 


BDEN=1 . First TC throttle. 

(X=t X TAL) 


tDK 
tDLRL 


DMA Cycle 


100 
2*X 






ns 
ns 


XTAL=20MHz 
AnyXTAL(X=txTAL) 


DACK Low to HRE 
Low 


tRD 


HRE Pulse Width 


80 




ns 




tRLDV 
tRHDH 


HRE Low to Data 
Valid 





60 
70 


ns 
ns 


8-bit mode 
1 6-bit mode 


HRE High to DACK 
High 


tDHRH 


Data Hold from HRE 
High 


5 




ns 




tRHDI 


HRE High to Data tri- 
state 




50 


ns 




tDRI 


DACK and HRE 
Inactive. 


20 




ns 





TABLE 18. AT/XT DMA READ TIMING 
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5.3.5 Slave Host Write Timings 



LOCAL MICROCONTROLLER INTERFACE 



ADO 

THRU 

AD7 



MDO 

THRU 

MD7 



>-j<SB 1 C 



SBIC REGISTER # 



49 y ^ WF 

>«— t A 



HOST INTERFACE 



HDO 

THRU 

HD7 



SBIC REGISTER # 



S= 



* MWHAL 

* MWHAL 



- Iaval 

l ALAI 



SBIC REGISTER # 






x 



REGISTER READ DATA 



v\ 



1 MWHWL - 
^ALWL — 



N/~ 



-'DVWH- 
1 WHDI — * 



FIGURE 12. SLAVE HOST WRITE TIMING 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


tWHWL 


Address Port Write to 
Data Write Recovery 
Time 


120 


10000 


ns 




tMWHAL 


MWE to HALE Delay 




150 


ns 




tAVAL 


HD Address Setup to 
HALE Low 


40 




ns 


AD setup to MWE (tADVWH)=130 ns 


tALAI 


HD Address Hold From 
HALE low 







ns 




tALWL 


HALE Low To HWE 
Low 


90 




ns 




tDVWH 


HD Valid to HWE High 


70 




ns 


AD setup to MWE (tADVWH)=130 ns 


tWHDI 


HD Inactive from HWE 







ns 




tMWHWL 


MWE Low to HWE Low 




150 


ns 




tMHWH 


MWE High to HWE 
High 




150 


ns 





TABLE 19. SLAVE HOST WRITE TIMING 
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5.3.6 Slave Host Read Timings 



LOCAL MICROCONTROLLER INTERFACE 



ALE 

ADO 

THRU 

AD7 



-^ 4B ^> [<JBIC REGISTER # )>■ 




HWE 
HCS 



FIGURE 13. SLAVE HOST READ TIMING 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


CONDITIONS 


tWHALH 


Address Port Write to 
ALE High Read 
Recovery Time 


400 10000 


ns 


tHRLDV=210nS 


tMWHAL 


MWE to HALE Delay 




150 


ns 




tMWHRE 


MWE to HRE Delay 




150 


ns 




tAVAL 


HD Address Setup to 
HALE Low 


40 




ns 


AD setup to MWE (tADVWH)=130 
ns. 


tALAI 


HD Address Hold from 
HALE Low 







ns 




tHDSA 


HD Data Setup to ALE 
High 


40 




ns 




tHDHA 


HD Data Hold from 
ALE High 


40 




ns 




tMRHRH 


MRE Low to HRE High 
Delay 







ns 




tHRLDV 


HRE Low to HD Data 
Valid Delay 








tHRLDV is a function of the slave 
peripheral device and only affects 

tWHALH- tWALH = tMWHRE + tHRLDV 
+ tHDSA 



TABLE 20. SLAVE HOST READ TIMING 
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DATA TRANSFER TIMING 
RCS 



\| 



HWE 
(IN) 



HDO 

THRU 

HD7 



HWE 
(OUT) 



THROTTLE TIMING 

RCS 



"N 



\ 



SW6 

V — M 



mczjmczmczymcDm- 



^ 



HWE 



DREQ 



\ 



NOTE 1 NOTE 2 



SINGLE TRANSFER TIMING 

DREQ 



/ 



RCS 



HWE 



A 



/ 



\—f\U 



NOTE 3 



FIGURE 14. SLAVE HOST DMA WRITE TIMING 
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5.3.7 Slave Host DMA Write Timing 










SYMBOL 


CHARACTERISTIC 


MIN 
BIN 02 
BIN 03 
BIN 05 


MAX 
BIN 02 
BIN 03 
BIN 05 


UNITS 


CONDITIONS 


tswi 


RCS Low to HWE First 
Transfer of Burst 





o 




ns 




tsW2 


HD Valid to HWE Rising 


30 
30 
30 




ns 




ts\A/3 


HWE Rising to HD In- 
valid 


15 
15 
15 




ns 




tSW4 


HWE Cycle Time 


200 
200 
100 




ns 


tXTAL < tsW4 / 
2 


tSW5 


HWE Low Pulse Width 


80 
80 
30 




ns 




tSW6 


HWE High Pulse 


30 
30 
30 




ns 




tSW7 


HWE Rising to DRQ Low 




4*X + 100 
4*X + 100 
4*X + 50 


ns 


Intermediate 
throttle. X = 

tXTAL 


tswio 
tswn 


RCS Low to DREQ Low 




100 
100 
50 

60 
60 
60 


ns 


Throttle when 
transfer 
count < 16 or 
single trans- 
fer mode 

HSMB=1 


DACKLowtoHWEOut 
Tri-state 




TABLE 21. SLAVE HOST DMA WRITE TIMING 



The following notes apply to Figure 15. 

NOTE1 

SBIC guarantees no transfer here at 5 
transfer rate. 

NOTE 2 
SBIC guarantees no transfer here at 10 
transfer rate. 

NOTE 3 
SBIC guarantees no transfer here. 



MB/s 



MB/s 



Although four transfers may occur after the FIFO 
goes almost full at 10 MB/s and only 3 bytes 
remain at that time, the buffer manage guarantees 
that at least 1 additional transfer occurs out of the 
FIFO prior to the fourth host transfer after the al- 
most full condition. This guarantees that no over- 
run condition occurs. 



sss 
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DATA TRANSFER TIMING 



\i 



HRE 
(IN) 



HDO 

THRU 

HD7 



HRE 
(OUT) 



Y 



/ — \ / — \ 



\ / 



f~v^ 



mzDmt—>mttwi3+ 



\ 



THROTTLE TIMING 
RCS 



f 



HRE 



DREQ 



\ 



NOTE 1 NOTE 2 



— — — — t SW7 — — — — — » 

~^ 



SINGLE TRANSFER TIMING 

DREQ 



/ 



A 



ECS 



HRE 



"\ 



' SW10 """ * 



J 



\-rsu 



NOTE 3 



FIGURE 15. SLAVE HOST DMA READ TIMING 
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5.3.8 Slave Host DMA Read Timing 










SYMBOL 


CHARACTERISTIC 


MIN 
BIN 02 
BIN 03 
BIN 05 


MAX 
BIN 02 
BIN 03 
BIN 05 


UNITS 


CONDITIONS 


tswi 


RCS Low to HD Valid 
First Transfer of Burst 





o 




ns 




tSW2 


HRE Rising to HD Valid 


5 
5 
5 


180 
180 
180 


ns 




tSW3 


RCS Low to First HRE 
Rising Edge 


140 
140 
100 




ns 




tSW4 


HRE Cycle Time 


200 
200 
100 




ns 


tXTAL < tsW4 / 

2 


tSW5 


HRE Low Pulse Width 


80 
80 
30 




ns 




tSW6 


HRE High Pulse 


30 
30 
30 




ns 




tSW7 


HRE Rising to DRQ Low 




4*X + 100 
4*X + 100 
4*X + 50 


ns 


Intermediate 
throttle. X = 

tXTAL 


tswio 
tswn 


RCS Low to DREQ Low 




100 
100 
50 

60 
60 
60 


ns 


Throttle when 
transfer 
count < 16 or 
single trans- 
fer mode 

HSMB = 1 


DACK Low to HRE Out 
Tri-state 




TABLE 22. SLAVE HOST DMA READ TIMING 



The following notes apply to Figure 16. 

NOTE1 

SBIC guarantees no transfer here at 5 
transfer rate. 

NOTE 2 
SBIC guarantees no transfer here at 10 
transfer rate. 

NOTE 3 
SBIC guarantees no transfer here. 



Although 4 transfers may occur after the FIFO 
goes almost full at 10 MB/s and only 3 bytes 
remain at that time, the buffer manage guarantees 

MB/s that at least 1 additional transfer occurs out of the 
FIFO prior to the fourth host transfer after the al- 
most full condition. This guarantees that no over- 

MB/s run condition occurs. 
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5.3.9 Buffer RAM Write Timing 

(Internal Oscillator; XTAL = 8 to 25 
MHZ) 



BAO 
THRU 
BA14 - 

BWE 

BDO 

THRU 

BD7 




« t 














AUUY 












\ 


X~ 




























4 BAHW 






^ 


l BAHW 










1 BASWL 

t 




\ 


l BW 




/ 




\ 


/ 


t 








BASWH 












« 


DTSW 


m 


4 USWH 




t 




DHW * 


< V 











FIGURE 16. BUFFER RAM WRITE TIMING (INTERNAL OSCILLATOR) 



SYMBOL 


CHARACTERISTIC 


MIN 
Bin 02 
Bin 03 
Bin 05 


MAX 


UNITS 


CONDITIONS 


tADCY 


Address Cycle Time 


2*tXTAL-28 
2*tXTAL-35 
2*tXTAL-25 




ns 


Any XTAL 


tBASWH 


Addres Setup to 
BWE High 


2*t X TAL-40 

2*tXTAL-55 
2*tXTAL-35 




ns 


Any XTAL 


tBASWL 


Addres Setup to 
BWE Low 


0.5*tXTAL-20 
0.5*tXTAL-35 

0.5*txTAL-20 




ns 


Any XTAL 


tBW 


BWE Pulse Width 


1.5*tXTAL-30 
1.5*tXTAL"35 
1.5*tXTAL-25 




ns 


Any XTAL 


tBAHW 


Address Hold From 
BWE High 


5 
5 
5 




ns 


Any XTAL 


tDSWH 


Data Valid to BWE 
High 


1 .5*tXTAL-40 
1.5*tXTAL-60 
1.5*tXTAL-35 




ns 


Any XTAL 


tDHW 


Data Hold from 
BWE High 


10 
10 
10 




ns 


Any XTAL 


tDTSW 


Data Tri-state from 
BWE High 




50 


ns 


Any XTAL 



TABLE 23. BUFFER RAM WRITE TIMING (INTERNAL OSCILLATOR) 
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5.3.1 Buffer RAM Read Timing 

(Internal Oscillator; XTAL = 8 to 20 
MHZ) 



BAO 


« * 


< 

4 












AUUY 








THRU \ 
BA14 / 


< > 










t 










l BASR 
t 


BAHR 






ADH 
t 












BAHR 


\ 


l BR 




/ 


BWE 
BDO 




\ 


/ 




t 












* t 








RDH 




4 RDS 




THRU «^fl ^t> 

BD7 ^^ ^^ 











FIGURE 17. BUFFER READ TIMING (INTERNAL OSCILLATOR) 



SYMBOL 


CHARACTERISTIC 


MIN 
20 MHz 
12 MHz 


UNITS 


CONDITIONS 


tADCY 


Address Cycle Time 


72 
125 


ns 


Max XTAL 


tADCY 


Address Cycle Time 


2*tXTAL"28 
2*tXTAL"35 


ns 


Any XTAL 


tBASR 


Address Setup to 
BOE High 


72 
125 


ns 


Max XTAL 


tBASR 


Address Setup to 
BOE High 


2*tXTAL"28 

2*txTAL-35 


ns 


Any XTAL 


tBR 


BOE Pulse Width 


45 
75 


ns 


Max XTAL 


tBR 


BOE Pulse Width 


1.5*tXTAL"30 
1.5*tXTAL"45 


ns 


Any XTAL 


tBAHR 


Address Hold from 
BOE High 






ns 


Any XTAL 


tRDS 


Data Setup to 
BOE High 


5 
5 


ns 


Any XTAL 


tRDH 


Data Hold from 
BOE High 


10 
10 


ns 


Any XTAL 


tDHW 


Data Hold from 
Address 


10 
10 


ns 




• All timings ir 
1.5V levels. 


l this table only are referenced to 
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BAO 

THRU 

BA14 

BWE 

BDO 

THRU 

BD7 










ADCY 
































\ 


/ 












> 


< 






BASW 


f 


BAHW 




















- t 


w 




* BA^ 




\ 




BW 




/ 






\ 


/ 


t 










DTSW 
t 






* DSWH 




DHW ' 



































FIGURE 18. BUFFER RAM WRITE TIMING (EXTERNAL OSCILLATOR) 
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5.3.11 Buffer RAM Write Timing (External Os- 
cillator; XTAL = 8 to 20 MHz) 



SYMBOL 


CHARACTERISTIC 


MIN MAX 
20 MHz 
12 MHz 


UNITS 


CONDITIONS 


tADCY 


Address Cycle Time 


72 
125 


ns 


Max XTAL 


tADCY 


Address Cycle Time 


2*txTAL-28 
2*txTAL-35 


ns 


Any XTAL 


tBASWL 


Address Setup to 
BWE Low 


5 
5 


ns 


Max XTAL/ 
50% XTAL 


tBASWL 


Address Setup to 
BWE Low 


txCH-20 
txCH-35 


ns 


Any XTAL 


tBASWH 


Address Setup to 
BWE High 


60 
105 


ns 


Max XTAL 


tBASWH 


Address Setup to 
BWE High 


2*tXTAL-40 
2*txTAL-55 


ns 


Any XTAL 


tBW 


BWE Pulse Width 


55 
85 


ns 


Max XTAL/ 
50% XTAL 


tBW 


BWE Pulse Width 


tXTAL+txCL-30 
tXTAL+txCL-35 


ns 


Any XTAL 


tBAHW 


Address Hold from 
BWE High 


5 
5 


ns 


Any XTAL 


tDSWH 


Data Valid to BWE 
High 


35 
60 


ns 


Max XTAL 


tDSWH 


Data Valid to BWE 
High 


tXTAL+txCH-40 
tXTAL+txCH-60 


ns 


Any XTAL/ 
%50 XTAL 


tDHW 


Data Hold from BWE 
High 


10 
10 


ns 


Any XTAL 


tDTSW 


Data tri-state from BWE 50 
High 


ns 


Any XTAL 


• All timings in this table only are referenced to 
1 .5 V levels except tDHW. 
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5.3.12 Buffer RAM Read Timing (External Os- 
cillator; XTAL=8 to 20 MHz) 
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FIGURE 19. BUFFER RAM READ TIMING (EXTERNAL OSCILLATOR) 



SYMBOL 


CHARACTERISTIC 


MIN UNITS 
20 MHz 
12 MHz 


CONDITIONS 


tADCY 


Address Cycle Time 


72 
125 


ns 


Max XTAL/50% XTAL 


tADCY 


Address Cycle Time 


2*tXTAL"28 
2*tXTAL"35 


ns 


Any XTAL 


tBASR 


Address Setup to 
BOE High 


72 
125 


ns 


Max XTAL/50% XTAL 


tBASR 


Address Setup to 
BOE High 


2*tXTAL"28 

2*txTAL-35 


ns 




tBR 


BOE Pulse Width 


45 
75 


ns 


Max XTAL/50% XTAL 


tBR 


BOE Pulse Width 


tXTAL+txCH-30 
tXTAL+txCH-45 


ns 


Any XTAL 


tBAHR 


Address Hold from 
BOE High 






ns 


Any XTAL 


tRDS 


Data Setup to BOE 
High 


5 
5 


ns 


Any XTAL 


tRDH 


Data Hold from BOE 
High 


10 
10 


ns 


Any XTAL 


tDHW 


Data Hold from Ad- 
dress 


10 
10 


ns 




• All timings 
levels. 


in this table referenced to 1 .5 V 
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5.3.1 3 Microprocessor Write Timing 
(INTEL Bus) 



ALE 



ADO 

THRU 

AD7 



MWE 



"X 
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DATA 
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FIGURE 20. MICROPROCESSOR WRITE TIMING (INTEL BUS) 



SYMBOL 


CHARACTERISTIC 


MIN 


UNITS 


CONDITIONS 


tAVAL 


Address Setup to ALE 
Low 


15 


ns 




tALAI 


Address Hold from ALE 
Low 


5 


ns 




tALEH 


ALE High Pulse Width 


30 


ns 




tADVWH 


Data Setup to MWE 


50 


ns 


HSMB=0 


tWHDI 


High 


130 
5 


ns 


HSMB=1 


Data Hold from MWE 




High 








tMWEL 


MWE Low Pulse Width 


75 


ns 




tADWL 


Address Valid to MWE 


55 


ns 




tWHLH 


Low 


10 


ns 




MWE High to ALE High 
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5.3.1 4 Microprocessor Write Timing 
(Motorola Bus) 




FIGURE 21. MICROPROCESSOR WRITE TIMING (MOTOROLA BUS) 



SYMBOL 


CHARACTERISTIC 


MIN 


UNITS 


CONDITIONS 


tAVAL 


Address Setup to AS 
Low 


15 


ns 




tALAI 


Address Hold from AS 


5 


ns 




tASH 


AS High Pulse Width 


30 


ns 




tADVDS 


Data Setup to DS Low 


50 
130 


ns 


HSMB=0 
HSMB=1 


tDSDI 


Data Hold from DS 
Low 


5 


ns 




tDSH 


DS High Pulse Width 
during Write 


75 


ns 




tWLDS 


R/W Low to DS High 


5. 


ns 




tDSWH 


DS Low to R/W High 


20 


ns 




tADDS 


Address High to DS 
High 


55 


ns 




tDSAH 


DS Low to AS High 


10 


ns 
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5.3.15 Microprocessor Read Timing (INTEL 
Bus) 
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FIGURE 22. MICROPROCESSOR READ TIMING (INTEL BUS) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tAVAL 


Address Setup to ALE 
Low 


15 




ns 


tALAI 


Address Hold from ALE 
Low 


5 




ns 


tALEH 


ALE High Pulse Width 


30 




ns 


tRLDV 


Data Valid from MRE 
Low 




100 


ns 


tDHRH 


Data Hold from MRE 
High 


10 




ns 


tRHDI 


Data Tri-state from 
MRE High 




50 


ns 


tMREL 


MRE Low Pulse Width 


100 




ns 


tADAR 


Address Valid to MRE 
Low 


55 




ns 


tRHLH 


MRE High to ALE High 


10 




ns 
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5.3.16 Microprocessor Read Timing (Motorola 
Bus) 
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FIGURE 23. MICROPROCESSOR READ TIMING (MOTOROLA BUS) 



SYMBOL 


CHARACTERISTIC 


MIN 


MAX 


UNITS 


tAVAL 


Address Setup to AS 
Low 


15 




ns 


tALAI 


Address Hold from AS 
Low 


5 




ns 


tASH 


AS High Pulse Width 


30 




ns 


tDSDV 


Data Valid from DS 
High 




100 


ns 


tDSDI 


Data Tri-state from DS 
Low 




50 


ns 


tDSH 


DS High pulse Width 
during Read 


100 




ns 


tADDS 


Address Valid to DS 
High 


55 




ns 


tDSAH 


DS Low to AS High 


10 




ns 



TABLE 30. MICROPROCESSOR READ TIMING (MOTOROLA BUS) 



26-80 



12/4/90 



'& 



ELECTRICAL AND TIMING SPECIFICATIONS 



WD42C22C 



5.3.17 Write Data Timing (MFM/RLL Mode; 
WC 5 to 15 MHz) 



WD 
WC 
LATE 
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FIGURE 24. WRITE DATA TIMING (MFM/RLL MODE) 



SYMBOL 


CHARACTERISTIC MIN MAX 
20 MHz 
12 MHz 


UNITS 


twc 


WC Pulse Width 28 
45 


500 
500 


ns 


tWLE 


Early/Late Propagation 3 
3 


15 
25 


ns 


tWD 


WD Propagation Delay 3 
3 


15 
25 


ns 


tWCF 


WC Frequency 1 
1 


15 
10 


MHz 
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5.3.18 Write Data Timing (NRZ Mode; WC 5 to 
15 MHz) 



FIGURE 25. WRITE DATA TIMING (NRZ MODE) 
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« tWD 
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SYMBOL 


CHARACTERISTIC 


MIN 
20 MHz 
12MHz 


MAX 


UNITS 


twCL 


WC Pulse Width Low 


20 
27 


500 
500 


ns 


tWCH 


WC Pulse Width High 


20 
27 


500 
500 


ns 


tWLE 


Early/Late Propagation 


3 
3 


15 
25 


ns 


tWD 


WD Propagation Delay 


3 
3 


15 
25 


ns 


twCF 


WC Frequency 


1 
1 


22 
16.5 


MHz 


tWCOL 


WCOUT Pulse Width 
Low 


tWCH - 5 
tWCH - 9 




ns 


twCOL 


WCOUT Pulse Width 
Low 




tWCH + 5 
tWCH + 9 


ns 


tWCOH 


WCOUT Pulse Width 
High 


tWCH - 5 
tWCH - 9 




ns 


tWCOH 


WCOUT Pulse Width 
High 




tWCH + 5 
tWCH + 9 


ns 


tWDWCO 


WD Prop Delay from 
WCOUT 


-5 
-8 


+5 
+8 


ns 
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5.3.19 Read Data Timing (MFM/RLL Mode; 
RC/WC5to15MHz) 



RR 
























/ 


/ 

« tF 


}D — 


\ 


\ 


/ 


/ 

« — tX2 ► 


~^s 




/ 


I/ 








« — txi 




Rr. / 


> 


< > 


C>C3 


< 


DRUN 


" t 














RCP * 








\ 


/ 


r~ 




/ 




\ 












« — t 














DRN 





FIGURE 26. READ DATA TIMING (MFM/RLL) 



SYMBOL 


CHARACTERISTIC 


MIN MAX 
20 MHz 
12 MHz 


UNITS 


tRCP 


RC Pulse Width 


27 
45 


500 
500 


ns 


tX1 


RC Transition to Next 
Leading RD 


5 
10 




ns 


tX2 


Leading RD to Next RC 10 
Transition 20 




ns 


tRD 


Read Data Pulse 
Width 


20 
30 


tRCP 
tRCP 


ns 


tDRN 


DRUN Low Pulse 
Width 


25 
25 




ns 


tRCF 


RC Frequency 


1 
1 


15 
10 


MHz 
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5.3.20 Read Data Timing (NRZ Mode; WC 5 to 
20MHz) 
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FIGURE 27. READ DATA TIMING (NRZ MODE) 



SYMBOL 


CHARACTERISTIC 


MIN MAX 
20 MHz 
12 MHz 


UNITS 


tRCP 


RC Pulse Width 


20 
27 


500 
500 


ns 


tRNS 


RD Setup to RC High 


7 
10 




ns 


tRNH 


RD Hold from RC High 7 
10 




ns 


tRCF 


RC Frequency 


1 
1 


22 
16.5 


MHz 
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5.3.21 Miscellaneous Timing 
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FIGURE 28. MISCELLANEOUS TIMING 
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SYMBOL 


CHARACTERISTIC MIN 


MAX 


UNITS 


CONDITIONS 


tlDX 


Index Pulse Width 100 




ns 




tSCT 


SCT Pulse Width 100 




ns 




tlWG 


Index to write gate 


4 WC periods 


Gap data=33 in RLL mode. Any 
gap data in MFM and NRZ. 


tWGWD 
tRSTI 

tMRW 


Write gate to write data 


4 WC periods 
WC periods 

lis 




RESET in pulse width 24 
low 

MR Trailing to Host 2.4 
Register Write 


Frcwc 


Difference of RC Fre- -1 5% +1 5% 
quency from WC Fre- 
quency 






tRSTL 
tRSTL 
tRSTL 


RESET Out Low Pulse 51.2 
Width during Power-up 




ms 
ms 
ms 


XTAL=10MHz 
XTAL=12.5MHz 
XTAL=20 MHz 


RESET Out Low Pulse 41.3 
Width during Power-up 


RESET Out Low Pulse 25.6 
Width during Power-up 


tXTAL 


Clock Period 50 
70 


125 


ns 




tXCH 


Clock High Time 25 
30 




ns 




txCL 


Clock Low Time 25 
30 

NOTE 




ns 




txTAL, txcH, and txcL timings at 2.5 V levels. 
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Repeated for Each Sector 



_r^ 



DRUN 



WG 



/ V 



J V 



(during FORMAT) 



WG 



(during WRITE) 



RG 



42C22A 
FORMAT 
# BYTES 



WGON- 



-C 



1 WGOFFf 



V 



It 



RGOFFr 



V 



I l RG0FF2 — ^ P 



RG0N1 



GAP 4 



GAP1 
n + 5 + CL 



IDPLO 
X + 9 



1 RGON2 ' 



ID 
PAD 2 



WRITE 
SPICE 

1 



DATA PLO 
(11) 



DATA 



DATA 

PAD 

3 



GAP 3 

n + 7 



IDPLO 
X + 9 



/ 



/ 



/ 












N 


A 


I 


C L 


H 


S 


c 


C 


1 


D 


Y 


E 


E 


R 


R 




E 


L W 


A 


C 


C 


C 




N 




D 


# 


1 


2 




T 













X+12+/-1 
(X = 0) 
X+13+/-1 
(X>0) 



/L 



\ 



128: 

256: 

512: 

1024: 

DATA 



2:CRC 
4:INT 

ECC 
7:INT 

ECC 



IDENT Definition: 
FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1 023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 



NOTES 

1. n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length Is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 11 during format. Data 
PLO length is 1 2 ± 1 (or x + 1 3 ± 1 ) during write if 
x = (x > 0). 



4. twGON = 

5. twGOFFI 

6. tRGOFFI 

7. tRGOFF2 

8. tRGONI 

DRUN. 

9. tRGON2 = 



17 + 1 bit times with respect to RD in. 
= 28 bit times with respect to WD out. 
= 9 ± 1 bit times with respect to RD in. 
= 9 ± 1 bit times with respect to RD in. 
= 19 + 1 bit times with respect to 

= 35 + 1 bit times with respect to RD in. 



FIGURE 29. SOFT SECTOR MFM/RLL TRACK FORMAT 
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Repeated for Each Sector 



INDEX 



y~^_ 



AME 

(during Format) 

AME _J~ 

(during R/W) 

AMF 



s\ 



"V 



-/TA. 



WG 

(during FORMAT) 



WG 



_/" 



(during WRITE) 



RG 



42C22A 
FORMAT 
# BYTES 



I 



'WREC 



'WGON- 



■c 



1 RG0FF1 — ►; 



MRGOFFT*! F" 



1 rgoff: 



*-! 



-J«- ^REC r4- 



1 RGON1 • 



GAP 4 



GAP1 
n+ 7 + CL 



ID PLC 
X + 8 



1 RGON2 " 



ID 
PAD 2 



WRITE 
SPICE 

1 



DATA PLO 
(11) 



DATA 



DATA 

PAD 

3 



\ 



/ 



\ 



WS 

1 



GAP 3 

n + 9 



ID PLO 
X + 8 



C L 
Y O E 
L WA 



X4 


12+/-1 


(X- 


= 0) 


X + 


13+/- 1 


(X>0) 









\ 


A 


F 


128: 


2:CRC 


1 


8 


256: 


4:INT 






512: 


ECC 






1024: 


7:INT 






DATA 


ECC 



IDENT Definition: 
FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1 535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 



NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 11 during format. Data 
PLO length is 1 2 ± 1 (or x + 1 3 ± 1 ) during write if 
x = (x > 0). 

4. twGON = 17 ± 1 bit times with respect to 
NRZRD in. 



5. twGOFFi = 28 bit times with respect to NRZWD 
out. 

6. tRGOFFi = 9 ± 1 bit times with respect to 
NRZRD in. 

7. tRGOFF2 = 9 ± 1 bit times with respect to 
NRZRD in. 

8. tRGOM = 3 ± 1 bit times with respect to AMF. 

9. tRGON2 = 35 + 1 bit times with respect to 
NRZRD in. 

10. twRREC = 21 to 35 bytes minimum. tRREC = 
23 bytes minimum. 



FIGURE 30. SOFT SECTOR NRZ TRACK FORMAT 
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Repeated for Each Sector 



INDEX 



SECTOR 



DRUN 



WG 

(during FORMAT) 



WG 

(during WRITE) 



RG 



42C22A 
FORMAT 
# BYTES 




/ 








\ 


\ 


A 

1 


I 
D 

E 
N 
T 


C L 
Y 
L W 


H 

E 
A 
D 


S 

E 
C 
# 


c 

R 
C 
1 


c 

R 
C 
2 



X + 


12+/-1 


(X = 


= 0) 


x + 


13+/-1 


(X> 


0) 



// 




N 


\ 


/ 


\ 


A 


F 


128: 


2:CRC 


1 


8 


256: 


4:INT 






512: 


ECC 






1024: 


7:INT 






DATA 


ECC 



IDENT Definition: 
FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1 535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 



NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL ^ 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 12 ± 1 (x + 13 ± 1) during write if x 
= (x > 0). 

4. twGON = 17 + 1 bit times with respect to RD in. 

5. twGOFFi = 28 bit times with respect to WD out. 

6. tRGOFFi =9 + 1 bit times with respect to RD in. 



7. tRGOFF2 = 9 + 1 bit times with respect to RD in. 

8. tRGONi = 19 + 1 bit times with respect to 
DRUN. SECTOR is tied to DRUNSCT during for- 
mat. DRUN is tied to DRUNSCT during read and 
write. 

9. tRGON2 = 35 + 1 bit times with respect to RD in. 

10. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 



FIGURE 31. HARD SECTOR RLL/MFM TRACK FORMAT 
(WITH SOFT SECTOR READ/WRITE) 
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Repeated for Each Sector 



INDEX 



SECTOR 



j~^ 



WG 

(during FORMAT) 



WG 



(during WRITE) 
RG 



Y^- 



1 WGON ~ 



-C 



1 WGOFF1 " 



[ RGOFFF* ! 



RGON1- 



42C22A 
FORMAT 
# BYTES 



GAP 4 



GAP1 
n + 5 + CL 



IDPLO 
X + 9 



\ * RGOFF2— *f I* 



RG0N2" 



ID 
PAD 2 



WRITE 
SPICE 

1 



DATA PLO 
(11) 
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D 
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C 

# 


C 
R 
C 

1 


c 

R 
C 
2 



/ 



/. 



•/ 



\^ 



GAP 2 



GAP 3 
n + 5 + CL 



IDPLO 
X + 9 



\ 



X4 


12+/-1 


(X 


= 0) 


X + 


13+/-1 


(X>0) 



A 


F 


128: 


2:CRC 


1 


8 


256: 
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IDENT Definition: 
FE = Cylinders 0-255 
FF = Cylinders 256-511 
FC = Cylinders 51 2-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1 535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 



NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 ^ CL ^ 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 12 ± 1 (x + 13 ± 1) during write if x 
= (x > 0). 

4. twGON = 17 ± 1 bit times with respect to RD in. 

5. twGOFFi = 28 bit times with respect to WD out. 

6. tRGOFFi = 9 ± 1 bit times with respect to RD in. 



7. tRGOFF2 = 9 ± 1 bit times with respect to RD in. 

8. tRGONi = z + CL byte times with respect to 
INDEX/SECTOR (SCT). SECTOR is tied to 
DRUNSCT always, z = contents of internal GAP 
register. 

9. tRGON2 = 35 + 1 bit times with respect to RD in. 

10. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 



FIGURE 32. HARD SECTOR RLL/MFM TRACK FORMAT 

(WITH HARD SECTOR READ/WRITE AND 
CONTINUOUS WG OPTION) 
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NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 12 ± 1 (or x + 13 ± 1) during write if 
x = (x > 0). 

4. twGON = 17 ± 1 bit times with respect to RD in. 

5. twGOFFi = 28 bit times with respect to WD out. 

6. tRGOFFi = 9 ± 1 bit times with respect to RD in. 

7. tRGOFF2 = 9 ± 1 bit times with respect to RD in. 



IDENT Definition: 
FE = Cylinders 0-255 
FF = Cylinders 256-511 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 



8. tRGONi = z .+ CL byte times with respect to 
INDEX/SECTOR (SCT). SECTOR is tied to 
DRUNSCT always, z = contents of internal GAP 
register. 

9. tRGON2 = 35 + 1 bit times with respect to RD in. 

10. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 

1 1 . tFWGON = n + 5 + CL byte times with respect 
to INDEX/SECTOR. twGOFF = 20 bit times with 
respect to WD out. 



FIGURE 33. HARD SECTOR RLL/MFM TRACK FORMAT 
(WITH HARD SECTOR READ/WRITE AND WG PULSE) 
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NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 ^ CL ^ 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 1 2 ± 1 (or x + 1 3 + 1 ) during write if 
x = 0. 

4. twGON = 17 ± 1 bit times with respect to 
NRZRDin. 

5. twGOFFi = 28 bit times with respect to NRZWD 
out. 

6. tRGOFFi = 9 ± 1 bit times with respect to 
NRZRD in. 



IDENT Definition: 
FE = Cylinders 0-255 
FF = Cylinders 256-511 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 



7. tRGOFF2 = 9 ± 1 bit times with respect to 
NRZRD in. 

8. tRGONi = z + CL byte times with respect to 
INDEX/SECTOR (SCT). z = contents of internal 
GAP register. 

9. tRGON2 = 35 + 1 bit times with respect to 
NRZRDin. 

10. twGLOW = 2 bit times. twGOFF2 = 8 bit times. 
Both timings with respect to NRZWD out. 

11. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 



FIGURE 34. HARD SECTOR NRZ TRACK FORMAT 
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5.4 Package Diagrams 
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FIGURE 35. 84 LEAD PLCC 
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FIGURE 36. 84 LEAD PQFP 
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